Home > Backend Development > PHP Tutorial > PHP function html_entity_decode() that converts html entities into characters

PHP function html_entity_decode() that converts html entities into characters

黄舟
Release: 2023-03-16 22:06:02
Original
1801 people have browsed it

实例

把 HTML 实体转换为字符:

<?php
$str = "&lt;&copy; W3CS&ccedil;h&deg;&deg;&brvbar;&sect;&gt;";
echo html_entity_decode($str);
?>
Copy after login

上面代码的 HTML 输出如下(查看源代码):

<!DOCTYPE html>
<html>
<body>
<© W3CSçh°°¦§>
</body>
</html>
Copy after login

上面代码的浏览器输出如下:

<© W3CSçh°°¦§>
Copy after login

定义和用法

html_entity_decode() 函数把 HTML 实体转换为字符。

html_entity_decode() 函数是 htmlentities() 函数的反函数。

语法

html_entity_decode(string,flags,character-set)
Copy after login
参数描述
string必需。规定要解码的字符串
flags可选。规定如何处理引号以及使用哪种文档类型。

可用的引号类型:

  • ENT_COMPAT - 默认。仅解码双引号。

  • ENT_QUOTES - 解码双引号和单引号。

  • ENT_NOQUOTES - 不解码任何引号。

规定使用的文档类型的附加 flags:

  • ENT_HTML401 - 默认。作为 HTML 4.01 处理代码。

  • ENT_HTML5 - 作为 HTML 5 处理代码。

  • ENT_XML1 - 作为 XML 1 处理代码。

  • ENT_XHTML - 作为 XHTML 处理代码。

character-set可选。一个规定了要使用的字符集的字符串。

允许的值:

  • UTF-8 - 默认。ASCII 兼容多字节的 8 位 Unicode

  • ISO-8859-1 - 西欧

  • ISO-8859-15 - 西欧(加入欧元符号 + ISO-8859-1 中丢失的法语和芬兰语字母)

  • cp866 - DOS 专用 Cyrillic 字符集

  • cp1251 - Windows 专用 Cyrillic 字符集

  • cp1252 - Windows 专用西欧字符集

  • KOI8-R - 俄语

  • BIG5 - 繁体中文,主要在台湾使用

  • GB2312 - 简体中文,国家标准字符集

  • BIG5-HKSCS - 带香港扩展的 Big5

  • Shift_JIS - 日语

  • EUC-JP - 日语

  • MacRoman - Mac 操作系统使用的字符集

注释:在 PHP 5.4 之前的版本,无法被识别的字符集将被忽略并由 ISO-8859-1 替代。自 PHP 5.4 起,无法被识别的字符集将被忽略并由 UTF-8 替代。

技术细节

返回值: 返回已转换的字符串。

PHP 版本: 4.3.0+

更新日志在 PHP 5 中,character-set 参数的默认值改为 UTF-8。

在 PHP 5.4 中,新增了用于规定使用的文档类型的附加 flags:ENT_HTML401、ENT_HTML5、ENT_XML1 和 ENT_XHTML。
在 PHP 5.0 中,新增了对多字节编码的支持。

更多实例

实例 1

把一些 HTML 实体转换为字符:

<?php
$str = "Jane &amp; &#039;Tarzan&#039;";
echo html_entity_decode($str, ENT_COMPAT); // Will only convert double quotes
echo "<br>";
echo html_entity_decode($str, ENT_QUOTES); // Converts double and single quotes
echo "<br>";
echo html_entity_decode($str, ENT_NOQUOTES); // Does not convert any quotes
?>
Copy after login

上面代码的 HTML 输出如下(查看源代码):

<!DOCTYPE html>
<html>
<body>
Jane & &#039;Tarzan&#039;<br>
Jane & &#39;Tarzan&#39;<br>
Jane & &#039;Tarzan&#039;
</body>
</html>
Copy after login

上面代码的浏览器输出如下:

Jane & &#39;Tarzan&#39;
Jane & &#39;Tarzan&#39;
Jane & &#39;Tarzan&#39;
Copy after login

实例 2

通过使用西欧字符集,把一些 HTML 实体转换为字符:

<?php
$str = "My name is &Oslash;yvind &Aring;sane. I&#039;m Norwegian.";
echo html_entity_decode($str, ENT_QUOTES, "ISO-8859-1");
?>
Copy after login

The HTML output of the code above will be (View Source):

<!DOCTYPE html>
<html>
<body>
My name is Øyvind Åsane. I&#39;m Norwegian.
</body>
</html>
Copy after login

上面代码的浏览器输出如下:

My name is Øyvind Åsane. I&#39;m Norwegian.
Copy after login

htmlentities(); html_entity_decode(); htmlspecialchars();

$a = &#39;<div><p>11111#11</p></div> /s #1&#39;;
            $b = htmlentities($a);
            echo &#39;htmlentities: &#39;.$b;
            echo "<br>";
            $c = html_entity_decode($b);
            echo &#39;html_entity_decode: &#39;.$c;
            $d = htmlspecialchars($a);
            echo "htmlspecialchars: ".$d;
Copy after login
htmlentities: <div><p>11111#11</p></div> /s #1


html_entity_decode:
11111#11

/s #1


htmlspecialchars: <div><p>11111#11</p></div> /s #1
Copy after login

The above is the detailed content of PHP function html_entity_decode() that converts html entities into characters. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template