PHP strip_tags 字符串函数
-
定义和用法
strip_tags - 从字符串中去除 HTML 和 PHP 标记 -
版本支持
PHP4 PHP5 PHP7 支持 支持 支持 V5.3.4 strip_tags()忽略allowable_tags中的自闭合XHTML标记。
V5.0.0 strip_tags() 变为二进制安全的。
警告:由于 strip_tags() 无法实际验证 HTML,不完整或者破损标签将导致更多的数据被删除。
警告:该函数不会修改 allowable_tags 参数中指定的允许标记的任何属性,包括 style 和 onmouseover 属性,用户可能会在提交的内容中恶意滥用这些属性,从而展示给其他用户。
-
语法
strip_tags (string $str [, string $allowable_tags ])
该函数尝试返回给定的字符串 str 去除空字符、HTML 和 PHP 标记后的结果。它使用与函数 fgetss() 一样的机制去除标记。 -
参数
参数 必需的 描述 str 是 输入字符串。 allowable_tags 否 使用可选的第二个参数指定不被去除的字符列表。 HTML 注释和 PHP 标签也会被去除。这里是硬编码处理的,所以无法通过 allowable_tags 参数进行改变。
在php 5.3.4及更高版本中,自动关闭的xhtml标记被忽略,在 allowable_tags 中只应使用非自动关闭的标记。例如,要同时允许<br>和<br/>,应使用:
strip_tags($input, '<br>');
输入 HTML 标签名字如果大于 1023 字节(bytes)将会被认为是无效的,无论 allowable_tags 参数是怎样的。
-
返回值
返回处理后的字符串。 -
示例
尝试一下<?php $text = '<p>尝试段落。</p><!-- Comment --> <a href="#fragment">其他文字</a>'; echo strip_tags($text); echo "<hr/>"; // 允许 <p> 和 <a> echo strip_tags($text, '<p><a>'); ?>
-
相关函数
htmlspecialchars() - 将特殊字符转换为 HTML 实体