PHP的防御XSS注入的终极解决方案
程序员文章站
2022-03-17 23:30:30
...
PHP的防御XSS注入的终极解决方案【信息安全】【Hack】
一:PHP直接输出html的,可以采用以下的方法进行过滤:
1.htmlspecialchars函数
2.htmlentities函数
3.HTMLPurifier.auto.php插件
4.RemoveXss函数(百度可以查到)
二:PHP输出到JS代码中,或者开发Json API的,则需要前端在JS中进行过滤:
1.尽量使用innerText(IE)和textContent(Firefox),也就是jQuery的text()来输出文本内容
2.必须要用innerHTML等等函数,则需要做类似php的htmlspecialchars的过滤(参照@eechen的答案)
三:其它的通用的补充性防御手段
1.在输出html时,加上Content Security Policy的Http Header
(作用:可以防止页面被XSS攻击时,嵌入第三方的脚本文件等)
(缺陷:IE或低版本的浏览器可能不支持)
2.在设置Cookie时,加上HttpOnly参数
(作用:可以防止页面被XSS攻击时,Cookie信息被盗取,可兼容至IE6)
(缺陷:网站本身的JS代码也无法操作Cookie,而且作用有限,只能保证Cookie的安全)
3.在开发API时,检验请求的Referer参数
(作用:可以在一定程度上防止CSRF攻击)
(缺陷:IE或低版本的浏览器中,Referer参数可以被伪造)
更多PHP相关知识,请访问PHP教程!
以上就是PHP的防御XSS注入的终极解决方案的详细内容,更多请关注其它相关文章!
推荐阅读
-
PHP开发中常见的安全问题详解和解决方法(如Sql注入、CSRF、Xss、CC等)
-
PHPTaint-检测xss/sqli/shell注入的php扩展模块
-
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案
-
万能密码的SQL注入漏洞其PHP环境搭建及防御手段
-
php防xss防sql注入的代码
-
PHP中防止SQL注入攻击和XSS攻击的两个简单方法
-
XSS注入我也不怕不怕啦--PHP从框架层面屏蔽XSS的思考和实践
-
CI框架怎么删除URL中index.php的终极解决方案
-
PHP防XSS 防SQL注入的代码
-
PHP中防止SQL注入攻击和XSS攻击的两个简单方法_PHP教程