相信你们在作***测试的时候都有过这样的经历,明明一个XSS的漏洞,可是却有XSS过滤规则或者WAF保护致使咱们不能成功利用,好比咱们输入<scirpt>alert("hi")</script>,会被转换为<script>alert(>xss detected<)</script>,这样的话咱们的XSS就不生效了,下面就教你们几种简单的绕过XSS的方法:javascript
一、绕过 magic_quotes_gpcphp
magic_quotes_gpc=ON是php中的安全设置,开启后会把一些特殊字符进行轮换,好比'(单引号)转换为\',"(双引号)转换为\" ,\转换为\\html
好比:<script>alert("xss");</script>会转换为<script>alert(\"xss\");</script>,这样咱们的xss就不生效了。java
针对开启了magic_quotes_gpc的网站,咱们能够经过javascript中的String.fromCharCode方法来绕过,咱们能够把alert("XSS");转换为web
String.fromCharCode(97, 108, 101, 114, 116, 40, 34, 88, 83, 83, 34, 41)那么咱们的XSS语句就变成了安全
<script>String.fromCharCode(97, 108, 101, 114, 116, 40, 34, 88, 83, 83, 34, 41, 59)</script> xss
String.fromCharCode()是javascript中的字符串方法,用来把ASCII转换为字符串。ide
如何转换ASCII码呢?工具
咱们能够使用 hackbar 来搞定,Firefox的扩展工具https://addons.mozilla.org/en-US/firefox/addon/hackbar/测试