这篇文章主要介绍了详解php函数 strip_tags 处理字符串缺陷bug的相关资料,需要的朋友可以参考下
详解PHP函数 strip_tags 处理字符串缺陷bug
PHP 函数 strip_tags() 是一个常用函数,该函数可以剥去字符串中的 HTML、XML 以及 PHP 的标签。极大方便了对字符串的操作,但是 strip_tags() 函数存在缺陷bug,由于 strip_tags() 无法验证 HTML 不完整或者破损标签将导致更多的数据被删除。
例子:
$str = 'string
立即学习“PHP免费学习笔记(深入)”;
string
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版下载动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
hello string
立即学习“PHP免费学习笔记(深入)”;
'; echo strip_tags($str, '');
输出:
string
立即学习“PHP免费学习笔记(深入)”;
string
通过 strip_tags 函数过滤 标签,其实我希望得到下面这个结果:
string
立即学习“PHP免费学习笔记(深入)”;
stringstring 立即学习“PHP免费学习笔记(深入)”;
导致我们未能得到所期望的结果,其实是因为字符串中第三个 string 左边那个尖括号,strip_tags 函数误删除了其他字符。
经过查找 PHP 相关文档发现 strip_tags 函数 有一个警告:由于 strip_tags() 无法实际验证 HTML,不完整或者破损标签将导致更多的数据被删除。
既然不能验证 HTML 标签完整性,遇到字符串中包含“”导致误删字符串中其他字符。











