本文实例讲述了php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法。分享给大家供大家参考,具体如下:
这个函数非常重要,特别是在处理中文字符时,同时开发过程中往往需对写入数据库或读取数据库的数据进行处理。
htmlspecialchars(string,flags,character-set,double_encode)
1、string:必需。规定要转换的字符串。
2、flags:可选,规定如何处理引号、无效的编码以及使用哪种文档类型,如ENT_COMPAT、ENT_QUOTES、ENT_NOQUOTES
3、character-set:可选,顾名思义字符集,默认utf-8,当然支持很多编码,这里不列举
4、double_encode:可选,一个规定了是否编码已存在的 HTML 实体的布尔值。
预定义的字符是:
1、 (和号)成为
2、” (双引号)成为 ”
3、' (单引号)成为 ‘
4、 (小于)成为 > (大于)成为 >
那么什么是HTML实体?
1、 在 HTML 中,某些字符是预留的。
2、在 HTML 中不能使用小于号()和大于号(>),这是因为浏览器会误认为它们是标签,当然在HTML中还有其他实体
3、如果希望正确地显示预留字符,我们必须在HTML源代码中使用字符实体(character entities)。
4、如需显示小于号,我们必须这样写: 或 使用实体名而不是数字的好处是,名称易于记忆。不过坏处是,浏览器也许并不支持所有实体名称(对实体数字的支持却很好)。
示例:
?php
$str = "Apple 'Orange'";
echo htmlspecialchars($str, ENT_COMPAT); // 默认,仅编码双引号
//在右键查看源代码下结果为:Apple 'Orange'
echo htmlspecialchars($str, ENT_QUOTES); // 编码双引号和单引号
//在右键查看源代码下结果为:Apple 'Orange'
echo htmlspecialchars($str, ENT_NOQUOTES); // 不编码任何引号
//在右键查看源代码下结果为:Apple 'Orange'
//扩展阅读htmlspecialchars_decode() — 将特殊的 HTML 实体转换回普通字符
?>
补充:htmlspecialchars_decode() — 将特殊的 HTML 实体转换回普通字符
htmlspecialchars_decode()
函数把一些预定义的 HTML 实体转换为字符。
被解码的 HTML 实体:
解码成 (和号)
quot; 解码成 " (双引号)
' 解码成 ' (单引号)
lt; 解码成 (小于)
gt; 解码成 > (大于)
示例:
?php
$str = "This is some lt;bgt;boldlt;/bgt; text.";
echo htmlspecialchars_decode($str);
?>
输出:
This is some b>bold/b> text..
PS:这里再为大家推荐几款相关在线工具供大家参考使用:
HTML/XML转义字符对照表:
http://tools.jb51.net/table/html_escape
在线HTML转义/反转义工具:
http://tools.jb51.net/transcoding/html_transcode
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php常用函数与技巧总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
您可能感兴趣的文章:- php框架CI(codeigniter)自动加载与自主创建对象操作实例分析
- 关于PHP5.6+版本“No input file specified”问题的解决
- 为Plesk PHP7启用Oracle OCI8扩展方法总结
- nginx+php出现No input file specified解决办法
- PHP htmlspecialchars()函数用法与实例讲解
- PHP htmlspecialchars_decode()函数用法讲解
- PHP htmlspecialchars() 函数实例代码及用法大全
- PHP之CI框架学习讲解