htmlspecialchars函数有三个参数,第一个参数是需要转换的字符串,第二个参数用于设置如何编码单引号和双引号,第三个参数规定要使用的字符集,其中第一个参数是必须的,第二个和第三个是可选的,至于后两个参数的值,大家可以查看PHP参考手册,这里我就不罗列了。

htmlspecialchars函式将特殊字元转成 HTML 的字串格式 ( &....; )。最常用到的场合可能就是处理客户留言的留言版了。

预定义的字符是:

  • & (和号)成为 &
  • " (双引号)成为 "
  • ' (单引号)成为 '
  • < (小于)成为 &lt;
  • > (大于)成为 &gt;

此函式只转换上面的特殊字元,并不会全部转换成 HTML 所定的 ASCII 转换。

 

下面来看htmlspecialchars函数的基本使用实例:

<?php
$html = \"<a href=\'fletch.html\'>Stew\'s favorite movie.</a>\\n\";
print htmlspecialchars($html).\"<br/>\";                
print htmlspecialchars($html, ENT_QUOTES).\"<br/>\";    
print htmlspecialchars($html, ENT_NOQUOTES).\"<br/>\";
?>

在浏览器上输出结果如下:

<a href=\'fletch.html\'>Stew\'s favorite movie.</a> 
<a href=\'fletch.html\'>Stew\'s favorite movie.</a> 
<a href=\'fletch.html\'>Stew\'s favorite movie.</a> 

查看页面源码结果如下:

&lt;a href=\'fletch.html\'&gt;Stew\'s favorite movie.&lt;/a&gt;
<br/>&lt;a href=&#039;fletch.html&#039;&gt;Stew&#039;s favorite movie.&lt;/a&gt;
<br/>&lt;a href=\'fletch.html\'&gt;Stew\'s favorite movie.&lt;/a&gt;
<br/>
收藏 打印