php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法分析

2025-05-29 0 100

本文实例讲述了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、如需显示小于号,我们必须这样写:< 或 <使用实体名而不是数字的好处是,名称易于记忆。不过坏处是,浏览器也许并不支持所有实体名称(对实体数字的支持却很好)。

示例:

?

1

2

3

4

5

6

7

8

9

10
<?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 实体:

&amp; 解码成 & (和号)
&quot; 解码成 " (双引号)
' 解码成 ' (单引号)
&lt; 解码成 < (小于)
&gt; 解码成 > (大于)

示例:

?

1

2

3

4
<?php

$str = "This is some &lt;b&gt;bold&lt;/b&gt; text.";

echo htmlspecialchars_decode($str);

?>

输出:

This is some <b>bold</b> text..

希望本文所述对大家PHP程序设计有所帮助。

原文链接:https://www.cnblogs.com/jinsanguo/p/7637824.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 php过滤htmlspecialchars() 函数实现把预定义的字符转换为 HTML 实体用法分析 https://www.kuaiidc.com/92669.html

相关文章

发表评论
暂无评论