PHP中htmlentities和htmlspecialchars的使用及区别

每次去使用的时候都去查手册,我也不记得查了多少次了,顺便记录下,htmlentities和htmlspecialchars的功能都是一样的,即将预定义的字符转化为html实体。

主要作用:就是让浏览器输出html代码,不去解析该html代码了,比如说在发帖的时候,为了不让其输入的html代码生效,可以使用htmlspecialchars

两者区别:htmlentities转换所有的html标记,htmlspecialchars只格式化& ' " < 和 > 这几个特殊符号。

PHP实例:

 

  1. <?php
  2. $str = '<a href="http://www.phpddt.com">php点点通</a>';
  3. //不指定编码,中文会乱码
  4. echo htmlentities($str)."<br>";
  5. echo htmlentities($str, ENT_COMPAT , "UTF-8")."<br>";
  6. //因为html只转义预定义的几个字符,所以不用指定编码了,建议使用htmlspecialchars
  7. echo htmlspecialchars($str);
  8. ?>

 

结果如下:

<a href="http://www.phpddt.com">php���</a>
<a href="http://www.phpddt.com">php点点通</a>
<a href="http://www.phpddt.com">php点点通</a>

右键查看html源码:

&lt;a href=&quot;www.phpddt.com&quot;&gt;php&ccedil;‚&sup1;&ccedil;‚&sup1;&eacute;€š&lt;/a&gt;<br>&lt;a href=&quot;www.phpddt.com&quot;&gt;php点点通&lt;/a&gt;<br>&lt;a href=&quot;www.phpddt.com&quot;&gt;php点点通&lt;/a&gt;

关于该函数的参数可以看看官方文档说明:

htmlentities :http://www.w3school.com.cn/php/func_string_htmlentities.asp

htmlspecialchars :http://www.w3school.com.cn/php/func_string_htmlspecialchars.asp

posted @ 2016-12-25 20:16  天涯海角路  阅读(246)  评论(0)    收藏  举报