百科狗-知识改变命运!
--

htmlspecialchars_decode() - 将特殊的 HTML 实体转换回普通字符 - php 字符串函数

梵高1年前 (2023-11-21)阅读数 20#技术干货
文章标签常量

htmlspecialchars_decode()

(PHP 5 >= 5.1.0, PHP 7)

htmlspecialchars_decode() - 将特殊的 HTML 实体转换回普通字符 - php 字符串函数

将特殊的 HTML 实体转换回普通字符

说明

htmlspecialchars_decode(string $string[,int $flags= ENT_COMPAT | ENT_HTML401] ): string

此函数的作用和htmlspecialchars()刚好相反。它将特殊的HTML实体转换回普通字符。

被转换的实体有:&"(没有设置ENT_NOQUOTES时),'(设置了ENT_QUOTES时),<以及>

参数

$string

要解码的字符串

$flags

用下列标记中的一个或多个作为一个位掩码,来指定如何处理引号和使用哪种文档类型。默认为ENT_COMPAT | ENT_HTML401

有效的$flags常量
常量名说明
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_HTML401ENT_XML1ENT_XHTMLENT_HTML5等常量。

范例

一个htmlspecialchars_decode()的例子

以上例程会输出:

this -> "

this -> "

参见

  • htmlspecialchars()将特殊字符转换为 HTML 实体
  • html_entity_decode()Convert HTML entities to their corresponding characters
  • get_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)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)