htmlspecialchars_decode() - 将特殊的 HTML 实体转换回普通字符 - php 字符串函数
htmlspecialchars_decode()
(PHP 5 >= 5.1.0, PHP 7)
将特殊的 HTML 实体转换回普通字符
说明
htmlspecialchars_decode(string $string[,int $flags= ENT_COMPAT | ENT_HTML401] ): string此函数的作用和htmlspecialchars()刚好相反。它将特殊的HTML实体转换回普通字符。
被转换的实体有:&,"(没有设置ENT_NOQUOTES
时),'(设置了ENT_QUOTES
时),<以及>。
参数
$string要解码的字符串
$flags用下列标记中的一个或多个作为一个位掩码,来指定如何处理引号和使用哪种文档类型。默认为ENT_COMPAT | ENT_HTML401。
常量名 | 说明 |
---|---|
ENT_COMPAT | 转换双引号,不转换单引号。 |
ENT_QUOTES | 单引号和双引号都转换。 |
ENT_NOQUOTES | 单引号和双引号都不转换。 |
ENT_HTML401 | 作为HTML 4.01编码处理。 |
ENT_XML1 | 作为XML 1编码处理。 |
ENT_XHTML | 作为XHTML编码处理。 |
ENT_HTML5 | 作为HTML 5编码处理。 |
返回值
返回解码后的字符串。
更新日志
版本 | 说明 |
---|---|
5.4.0 | 增加了ENT_HTML401 、ENT_XML1 、ENT_XHTML 和ENT_HTML5 等常量。 |
范例
一个htmlspecialchars_decode()的例子
以上例程会输出:
this -> "
this -> "
参见
htmlspecialchars()
将特殊字符转换为 HTML 实体html_entity_decode()
Convert HTML entities to their corresponding charactersget_html_translation_table()
返回使用 htmlspecialchars 和 htmlentities 后的转换表
This should be the best way to do it. (Reposted because the other one seems a bit slower and because those who used the code under called it htmlspecialchars_decode_php4)
The example for "htmlspecialchars_decode()" below sadly does not work for all PHP4 versions. Quote from the PHP manual: "get_html_translation_table() will return the translation table that is used internally for htmlspecialchars() and htmlentities()." But it does NOT! At least not for PHP version 4.4.2. This was already reported in a bug report (http://bugs.php.net/bug.php?id=25927), but it was marked as BOGUS. Proof: Code: -------------------- -------------------- Output: -------------------- array '"' => '"' ''' => ''' '' => '>' '&' => '&' ''' -------------------- This comment now is not to report this bug again (though I really believe it is one), but to complete the example and warn people of this pitfall. To make sure your htmlspecialchars_decode fake for PHP4 works, you should do something like this: Br, Thomas
that works also with ä and " and so on. get_html_translation_table(HTML_ENTITIES) => offers more characters than HTML_SPECIALCHARS function htmlspecialchars_decode_PHP4($uSTR) { return strtr($uSTR, array_flip(get_html_translation_table(HTML_ENTITIES, ENT_QUOTES))); }
If you use `htmlspecialchars()` to change things like the ampersand (&) into it's HTML equivalent (&), you might run into a situation where you mistakenly pass the same string to the function twice, resulting in things appearing on your website like, as I call it, the ampersanded amp; "&". Clearly nobody want's "&" on his or her web page where there is supposed to be just an ampersand. Here's a quick and easy trick to make sure this doesn't happen: Now, if your dealing with text that is a mixed bag (has HTML entities and non-HTML entities) you're on your own.
Keep in mind that you should never trust user input - particularly for "mixed-bag" input containing a combination of plain text and markup or scripting code. Why? Well, consider someone sending '&alert('XSS');' to your PHP script:
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)