Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PHP 教程

PHP 主页 PHP 简介 PHP 安装 PHP 语法 PHP 注释 PHP 变量 PHP Echo / Print PHP 数据类型 PHP 字符串 PHP 数字 PHP 类型转换 PHP 数学 PHP 常量 PHP 魔术常量 PHP 运算符 PHP If...Else...Elseif PHP Switch PHP 循环 PHP 函数 PHP 数组 PHP 超全局变量 PHP 正则表达式

PHP 表单

PHP 表单处理 PHP 表单验证 PHP 表单必填项 PHP 表单 URL/电子邮件 PHP 表单完成

PHP 高级

PHP 日期和时间 PHP 包含 PHP 文件处理 PHP 文件打开/读取 PHP 文件创建/写入 PHP 文件上传 PHP Cookies PHP 会话 PHP 过滤器 PHP 过滤器高级 PHP 回调函数 PHP JSON PHP 异常

PHP OOP

PHP 什么是 OOP PHP 类/对象 PHP 构造函数 PHP 析构函数 PHP 访问修饰符 PHP 继承 PHP 常量 PHP 抽象类 PHP 接口 PHP 特性 PHP 静态方法 PHP 静态属性 PHP 命名空间 PHP 可迭代对象

MySQL 数据库

MySQL 数据库 MySQL 连接 MySQL 创建数据库 MySQL 创建表 MySQL 插入数据 MySQL 获取最后插入的 ID MySQL 插入多个 MySQL 预处理语句 MySQL 选择数据 MySQL Where MySQL Order By MySQL 删除数据 MySQL 更新数据 MySQL 限制数据

PHP XML

PHP XML 解析器 PHP SimpleXML 解析器 PHP SimpleXML - 获取 PHP XML Expat PHP XML DOM

PHP - AJAX

AJAX 简介 AJAX PHP AJAX 数据库 AJAX XML AJAX 实时搜索 AJAX 投票

PHP 示例

PHP 示例 PHP 编译器 PHP 测验 PHP 练习 PHP 服务器 PHP 证书

PHP 参考

PHP 概述 PHP 数组 PHP 日历 PHP 日期 PHP 目录 PHP 错误 PHP 异常 PHP 文件系统 PHP 过滤器 PHP FTP PHP JSON PHP 关键字 PHP Libxml PHP Mail PHP Math PHP Misc PHP MySQLi PHP 网络 PHP 输出控制 PHP 正则表达式 PHP SimpleXML PHP 流 PHP 字符串 PHP 变量处理 PHP XML 解析器 PHP Zip PHP 时区

PHP htmlspecialchars() 函数

❮ PHP 字符串参考

示例

将预定义的字符 "<"(小于)和 ">"(大于)转换为 HTML 实体

<?php
$str = "This is some <b>bold</b> text.";
echo htmlspecialchars($str);
?>

上面代码的 HTML 输出将是(查看源代码)

<!DOCTYPE html>
<html>
<body>
这是一些&lt;b&gt;粗体&lt;/b&gt;文本。
</body>
</html>

以上代码在浏览器中的输出将是

这是一些<b>粗体</b>文本。
自己尝试一下 »

定义和用法

htmlspecialchars() 函数将一些预定义的字符转换为 HTML 实体。

预定义的字符是

  • & (和号) 变成 &amp;
  • " (双引号) 变成 &quot;
  • ' (单引号) 变成 &#039;
  • < (小于) 变成 &lt;
  • > (大于) 变成 &gt;

提示: 要将特殊 HTML 实体转换回字符,请使用 htmlspecialchars_decode() 函数。


语法

htmlspecialchars(string,flags,character-set,double_encode)

参数值

参数 描述
string 必需。指定要转换的字符串。
flags 可选。指定如何处理引号、无效编码和使用的文档类型。

可用的引号样式为

  • ENT_COMPAT - 默认。仅编码双引号
  • ENT_QUOTES - 编码双引号和单引号
  • ENT_NOQUOTES - 不编码任何引号

无效编码

  • ENT_IGNORE - 忽略无效编码,而不是让函数返回空字符串。应该避免,因为它可能存在安全隐患。
  • ENT_SUBSTITUTE - 将指定字符集的无效编码替换为 Unicode 替换字符 U+FFFD (UTF-8) 或 &#FFFD;,而不是返回空字符串。
  • ENT_DISALLOWED - 将指定文档类型中无效的代码点替换为 Unicode 替换字符 U+FFFD (UTF-8) 或 &#FFFD;

指定使用文档类型的附加标志

  • 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 OS 使用的字符集

注意: 在 PHP 5.4 之前的版本中,无法识别的字符集将被忽略并替换为 ISO-8859-1。从 PHP 5.4 开始,它将被忽略并替换为 UTF-8。

double_encode 可选。一个布尔值,指定是否对现有的 html 实体进行编码。
  • TRUE - 默认。将转换所有内容
  • FALSE - 不会对现有的 html 实体进行编码


技术细节

返回值 返回转换后的字符串。

如果string包含无效编码,它将返回空字符串,除非设置了 ENT_IGNORE 或 ENT_SUBSTITUTE 标志。
PHP 版本 4+
变更日志 PHP 5.6 - 将character-set参数的默认值更改为默认字符集 (在配置中) 的值。
PHP 5.4 - 将character-set参数的默认值更改为 UTF-8。
PHP 5.4 - 添加了 ENT_SUBSTITUTE、ENT_DISALLOWED、ENT_HTML401、ENT_HTML5、ENT_XML1 和 ENT_XHTML
PHP 5.3 - 添加了 ENT_IGNORE 常量。
PHP 5.2.3 - 添加了double_encode参数。
PHP 4.1 - 添加了character-set参数。

更多示例

示例

将一些预定义的字符转换为 HTML 实体

<?php
$str = "Jane & 'Tarzan'";
echo htmlspecialchars($str, ENT_COMPAT); // 仅转换双引号
echo "<br>";
echo htmlspecialchars($str, ENT_QUOTES); // 转换双引号和单引号
echo "<br>";
echo htmlspecialchars($str, ENT_NOQUOTES); // 不转换任何引号
?>

上面代码的 HTML 输出将是(查看源代码)

<!DOCTYPE html>
<html>
<body>
Jane &amp; 'Tarzan'<br>
Jane &amp; &#039;Tarzan&#039;<br>
Jane &amp; 'Tarzan'
</body>
</html>

以上代码在浏览器中的输出将是

Jane & 'Tarzan'
Jane & 'Tarzan'
Jane & 'Tarzan'
自己尝试一下 »

示例

将双引号转换为 HTML 实体

<?php
$str = 'I love "PHP".';
echo htmlspecialchars($str, ENT_QUOTES); // 转换双引号和单引号
?>

上面代码的 HTML 输出将是(查看源代码)

<!DOCTYPE html>
<html>
<body>
I love &quot;PHP&quot;.
</body>
</html>

以上代码在浏览器中的输出将是

I love "PHP".
自己尝试一下 »

❮ PHP 字符串参考
×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.