Stage #11
根据提示,发现正则匹配,过滤掉了很多关键字
data:image/s3,"s3://crabby-images/0d8ce/0d8ce6ab87aed28fc2391f32fa00ddf9954372d6" alt=""
除on 事件和script 事件外,能执行js 代码的还有a 标签构造的超链接
构造 "><a href=javascript:alert(document.domain)>test</a><
data:image/s3,"s3://crabby-images/b5a58/b5a582dc07bf7310bc238ecaee72fe65ce9cbfc8" alt=""
发现仍然存在过滤,尝试用HTML 实体进行绕过,	 HTML tab制表符十进制编码
data:image/s3,"s3://crabby-images/f379c/f379cd385c0cf18ac45bc00b808c5082d7e4e9e8" alt=""
data:image/s3,"s3://crabby-images/215fd/215fdd42cfca4902fafdabb8bef3f6d76814ead8" alt=""
HTML 16进制转义符清单
ASCII 的十进制或者十六进制,加上不同的前缀转换成unicode,utf-8,html实体
查看源代码,成功绕过过滤
data:image/s3,"s3://crabby-images/74b67/74b67507b3ae6760faf282e7dc2a3506b5ea267f" alt=""
data:image/s3,"s3://crabby-images/e98e7/e98e75aea45431b979bb0d6ef49fd35c2857dbdd" alt=""
点击链接,得到下关入口
data:image/s3,"s3://crabby-images/429b9/429b9632551250e670a2c3e3587defd5c1596987" alt=""
Stage #12
测试代码,查看源代码
data:image/s3,"s3://crabby-images/5fc28/5fc2830023f60290e0a08d8b42a238e14785a5f7" alt=""
发现过滤了尖括号以及单双引号
IE8 特性会把`` 符号识别为双引号
尝试利用IE8 特性进行绕过
data:image/s3,"s3://crabby-images/b0ec9/b0ec999854d81f83b286eccab5a6bf42d98e7720" alt=""
成功绕过,弹窗通关
data:image/s3,"s3://crabby-images/ba299/ba2997e34e099daaf79894d28b05702d4dff7f7a" alt=""
Stage #13
查看源代码,发现多了一个style 属性
data:image/s3,"s3://crabby-images/6b61e/6b61eb3185b929fe86a70b2a3013dda7dad769c2" alt=""
利用行内样式的动态属性进行XSS
data:image/s3,"s3://crabby-images/555ff/555ffc45a03ae0b7c30e80aaa747b303d520a345" alt=""
插入代码 xss:expression(onmousemove=function(){alert(document.domain)})
点击通过,查看源代码
data:image/s3,"s3://crabby-images/24280/24280400ac7d2f337c198fbd02ebe5e12e73ee4b" alt=""
弹窗得到下关入口
data:image/s3,"s3://crabby-images/0e0c9/0e0c9f8b184ccf617ee3bc12f56069b0fc5ce828" alt=""
Stage #14
查看源代码,仍然是style 型XSS
插入代码 xss:expression(onmousemove=function(){alert(document.domain)})
data:image/s3,"s3://crabby-images/af365/af3653630936478b4e5e7047766d8befbf7c8b64" alt=""
expression 存在过滤,尝试用HTML 实体进行绕过
data:image/s3,"s3://crabby-images/4b358/4b3588cc86b5049169509d484232bb8131f3abdf" alt=""
& 存在过滤,尝试构建 xss:expre/**/ssion(onmousemove=function(){alert(document.domain)})
data:image/s3,"s3://crabby-images/a5400/a5400befb06ff0207bab8ca7f119063ba693f5b2" alt=""
成功绕过,弹窗得到下关入口
data:image/s3,"s3://crabby-images/96fd9/96fd9e41c490455b3eceeb89af9fbb38191b087a" alt=""
f. 绕过WAF 的几种常见方法
data:image/s3,"s3://crabby-images/67ad2/67ad265cae0c48078e9749a0eb1a0b00b8902358" alt=""
data:image/s3,"s3://crabby-images/5e916/5e91680aacca3c5b809d6d05464dc7768fc984a8" alt=""
Stage #15
DOM 型 XSS
document对象write方法,用于向文档写入 HTML 表达式或 JavaScript 代码。
data:image/s3,"s3://crabby-images/d8ec5/d8ec5e8901e88ffc23a37446c3cf34c47203310a" alt=""
测试代码</xss>
data:image/s3,"s3://crabby-images/29d75/29d75aa18895e120be4d5da638a86d30cdeda08f" alt=""
过滤了尖括号,尝试十六进制编码绕过
data:image/s3,"s3://crabby-images/6b7a4/6b7a40ea65e3e4a12071d2eae1407e794d8edca4" alt=""
过滤了反斜杠,而不是转化反斜杠,双斜杠绕过
data:image/s3,"s3://crabby-images/3e9ca/3e9ca6dd79c0d6fa586d103f69f6b4e5e31cd931" alt=""
成功绕过,得到入口
data:image/s3,"s3://crabby-images/c9874/c987433798e422c714ded569fa60721f355eb7dc" alt=""
❤