php过滤输入操作之htmlentities与htmlspecialchars用法分析
本篇章节讲解php过滤输入操作htmlentities与htmlspecialchars用法。分享给大家供大家参考,具体如下: 过滤输入 (即来自所列数据源中的任何数据)是指,转义或删除不安全的字符。在数据到达应用的存储层之前,一定要过滤输入数据。这是第一道防线。假如网站的评论表单接收html,默认情况下访客可以毫无阻拦地在评论中加入恶意的 上面例子。如果不过滤这个评论,恶意代码会存入数据库,然后再网站的标记中渲染。 HTML我们可以使用htmlentities或者htmlspecialchars函数来过滤html,把特殊字符转换成对应的html实体。 htmlentities这个函数转换所有含有对应“html实体”的特殊字符,比如货币表示符号欧元英镑等、版权符号等,htmlspecialchars 只是把某些特殊的字符转义了, & " ' < > 这2个函数比较傻,默认是不会转义单引号的 alert(213)';
//并没有转义单引号
echo $str;
echo "
".PHP_EOL; echo htmlentities($str); echo " ".PHP_EOL; echo htmlspecialchars($str); 需要设置第2个参数 ENT_QUOTES,具体可以看php手册 ".PHP_EOL; echo htmlspecialchars($str,'UTF-8');//单引号也转义以上例子并不能区别出htmlentities和htmlspecialchars ,下面换上一些特殊的字符,如欧元等。htmlentities将会对此转义,htmlspecialchars却不会 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |