很多朋友在写php的时候,难免会遇到需要将html标签进行转义存储。比如存入数据库、xml文件等。而存储进去后,读取出来则需要转换成html输出。网上有许多人编写的转换函数,很长很难懂。其实php早就自带有这样的函数。大可不必自己编写。

下面分别介绍这两个函数。

1.htmlentities()函数:

说明:将html标签转换成特殊字符。例如将<script>转换成”<script>”

例子:

[PHP]
  1. // An imaginary article submission from bad user  
  2. //  it will redirect anyone to example.com if the code is run in browser  
  3. $userInput “I am going to hax0r your site, hahaha!  
  4.     <script type='text/javascript'>  
  5.     window.location 'http://www.example.com/'  
  6.     </script>'”;  
  7.       
  8. //Lets make it safer before we use it  
  9. $userInputEntities htmlentities($userInput);  
  10.   
  11. //Now we can display it  
  12. echo $userInputEntities;  

由于最近csdn的控件比较垃圾,请将上面的$apos改成单引号。—呼!

上面的语句执行后,将生成下面的结果

[HTML]
  1. am going to hax0r your site, hahaha!  
  2.     <script type='text/javascript'>  
  3.     window.location 'http://www.88web.org/'  
  4.     </script>'  

2.html_entity_decode()函数

说明:将htmlentities()函数转义过的字符串转成html标签。

例子:

[PHP]
  1. $orig “I'll /”walk/” the <b>dog</b> now”;  
  2.   
  3. $a htmlentities($orig);  
  4.   
  5. $b html_entity_decode($a);  
  6.   
  7. echo $a; // will “walk” the <b>dog</b> now  
  8.   
  9. echo $b; // will “walk” the <b>dog</b> now 

php 解决超卖的几种方案(redis锁、mysql悲观锁)

1.创建商品和订单表模拟商品交易操作 fa_goods商品表,stock商品库存,test_order=订单表 2.添加一个测试商品数据(商品数量为150个) 测试并发购买的方法(gol...

阅读全文

centos8 yum安装php7.3

执行命令 $ yum install epel-release $ rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm $ dnf install -y https://rpms...

阅读全文

php面试题

php魔术方法 __get( $property ) 当调用一个未定义的属性时访问此方法 __set( $property, $value ) 给一个未定义的属性赋值时调用 __isset( $proper...

阅读全文

欢迎留言