关于在php中html标签的转换问题的解决

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

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

1.htmlentities()函数:

说明:将html标签转换成特殊字符。例如将<script>转换成"&lt;script&gt;"

例子:

  1. // An imaginary article submission from a bad user  
  2. //  it will redirect anyone to example.com if the code is run in a browser  
  3. $userInput = "I am going to hax0r your site, hahaha!  
  4.     <script type=&apos;text/javascript&apos;>  
  5.     window.location = &apos;http://www.example.com/&apos;  
  6.     </script>&apos;";  
  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改成单引号。---呼!

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

  1. I am going to hax0r your site, hahaha!  
  2.     <script type=&apos;text/javascript&apos;>  
  3.     window.location = &apos;http://www.88web.org/&apos;  
  4.     </script>&apos;  

2.html_entity_decode()函数

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

例子:

  1. $orig = "I&apos;ll /"walk/" the <b>dog</b> now";  
  2.   
  3. $a = htmlentities($orig);  
  4.   
  5. $b = html_entity_decode($a);  
  6.   
  7. echo $a; // I will "walk" the <b>dog</b> now  
  8.   
  9. echo $b; // I will "walk" the <b>dog</b> now  

 

转载自:http://blog.sina.com.cn/s/blog_a144530d0101d6li.html

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。