第 1 关(删除前端js校验)
点击第一关,我们可以看到页面上传区可以上传一个图片,我们要上传一个 webshell,这里我们上传一句话木马的 php
data:image/s3,"s3://crabby-images/cb3b4/cb3b41f11aa7cf107509e6f1f0e24a35f6cc5044" alt=""
点击上传
data:image/s3,"s3://crabby-images/61b9d/61b9d30a188415e400f43028c60e84372a4cf62d" alt=""
显示文件不支持上传,这时我们查看源码
data:image/s3,"s3://crabby-images/b0bdb/b0bdb071c6bbdff24775e947c711db23c59ec828" alt=""
查看代码后发现,只是在前端页面对输入的文件进行检查
我们右键页面点击检查
data:image/s3,"s3://crabby-images/aa452/aa45220e1ba302a4d48e0781ca143662f00d156c" alt=""
找到前端代码中检查的代码,我们给他删掉
data:image/s3,"s3://crabby-images/d86ca/d86ca839c1da9ec76d451e1e1aad36a58225d5b3" alt=""
之后我们继续上传木马文件
data:image/s3,"s3://crabby-images/2e29c/2e29c278170126e3ac33287ae00b55938f578cd5" alt=""
我们访问一下我们上传的 php 文件
data:image/s3,"s3://crabby-images/ec2f1/ec2f1a49287f1346447a2c1d63f00a12d6ff0d7f" alt=""
访问成功,说明文件上传成功
第 2 关(抓包文件类型校验)
现在来到该靶场的第二关,尝试直接上传一个php文件
data:image/s3,"s3://crabby-images/787a0/787a0de9691304466d6bbc76c9ab5c0755f37c4a" alt=""
显示文件类型不正确,这时我们查看一下源码
data:image/s3,"s3://crabby-images/87f2c/87f2c4020fca287b6f30da7740ddeb53ddbaea9b" alt=""
查看源码后发现,这里是对文件后端的页面进行检查,所以我们使用 bp 抓包
data:image/s3,"s3://crabby-images/3e423/3e42327a916164d1f1273694173385a51ca4379f" alt=""
我们将文件类型改为 image/jpeg
data:image/s3,"s3://crabby-images/b4fab/b4fab1f5efb80f2c9fc49cf8ff45e629b534323e" alt=""
返回页面
data:image/s3,"s3://crabby-images/ed5f5/ed5f5b27e33c462b98dcc682b625a5df7cb0604d" alt=""
我们还是访问一下文件
data:image/s3,"s3://crabby-images/38e27/38e274ae78a4271cf6a20fa55ade9e1e4f3e031e" alt=""
访问成功,文件上传成功
第 3 关(上传php同种类型的不同后缀)
来到了第三关,先来尝试上传一个php文件
data:image/s3,"s3://crabby-images/b3ce4/b3ce4267df8d0e3c7a61ece8ec883e6786775fe8" alt=""
显示不允许上传带有这些后缀的文件,我们去查看一下源码
data:image/s3,"s3://crabby-images/da176/da176e186acf5aa00f0ceb7dd4dd4609b6bcc3d1" alt=""
可以看到,这里对后缀为.asp .aspx .php .jsp都进行了拒绝,并且对文件中的特殊字符进行了很多的过滤,使用了很多名单的方式进行了校验,那么我们就可以上传一些没有限制的后缀,这里我们使用 php3 后缀名
data:image/s3,"s3://crabby-images/21e08/21e083e8ff841568d67619f14b879e4ac3fa6205" alt=""
点击上传
data:image/s3,"s3://crabby-images/da6ac/da6ac2af3543d8eb23951002919eec80ba8f8c91" alt=""
我们访问一下上传的 3.php3
data:image/s3,"s3://crabby-images/37b6e/37b6e797499e496dbf6f741cb5b0050ff4fffa76" alt=""
访问成功,文件上传成功
第 4 关(上传.htaccess配置文件)
来到了第三关,先来尝试上传一个php文件
data:image/s3,"s3://crabby-images/f201d/f201dceb2c63517aef8b666934710bdba090dd0a" alt=""
我们查看源码
data:image/s3,"s3://crabby-images/e5884/e58846de21b2b46bdbc4270c2386e89b2d5d0a7e" alt=""
根据源码发现这些后缀的都无法上传,这时候就要用到.htaccess文件上传了
上传.htaccess配置文件
AddType application/x-httpd-php .png
data:image/s3,"s3://crabby-images/32556/325568618928edb77f8ac9f4f2e6dbe59403c926" alt=""
data:image/s3,"s3://crabby-images/889e0/889e0843da464e83f120438cf2f8c63dc7063603" alt=""
这时我们将 php 文件后缀改为 png 然后上传
data:image/s3,"s3://crabby-images/e83f7/e83f7afe2e1e808048516ba217400ef734eea7ed" alt=""
我们访问一下
data:image/s3,"s3://crabby-images/ccb95/ccb953e8e8ff5676d06fc015ba7152753b4d8bab" alt=""
访问成功,上传成功
第 5 关(大小写判断)
根据源码发现这关没有过滤大小写
data:image/s3,"s3://crabby-images/a83fe/a83feb91df57aa7ea2319bae5775b66e15f705fd" alt=""
data:image/s3,"s3://crabby-images/86bd6/86bd68c184b091eae5d53bc934adc740f396c5f0" alt=""
就可以上传成功了
第 6 关(空格绕过)
根据源码发现这关没有过滤首尾空格
data:image/s3,"s3://crabby-images/cdb55/cdb55060f742ca0769f5d4ec8141c0ec2049bc64" alt=""
在文件后面添加一个空格就可以上传成功了
data:image/s3,"s3://crabby-images/0983a/0983abf22c963c7a50abc74e29fb3a8eda06b5b2" alt=""
第 7 关(点绕过)
根据源码发现这关没有过滤文件末尾的点
data:image/s3,"s3://crabby-images/1d349/1d3491e9b7f6125d5d7cacd9fef0cf55a97a3900" alt=""
抓包修改文件名,在文件末尾加一个点,就可以上传成功
data:image/s3,"s3://crabby-images/6c3ed/6c3ed2b523727f7d29c5bdfb9f7f72b62d45aca3" alt=""
data:image/s3,"s3://crabby-images/2da7c/2da7c9180cca63fd455e3c2fdca07e83f6a454d2" alt=""
第 8 关(::$DATA绕过)
根据源码发现这关没有过滤::$DATA
data:image/s3,"s3://crabby-images/d0508/d0508d167d82b3fe8a744d3a1e12217e438ab40b" alt=""
在文件末尾加上::$DATA就可以成功上传
data:image/s3,"s3://crabby-images/302e6/302e68066f5191863dae766a0fc7f27305a0b634" alt=""
data:image/s3,"s3://crabby-images/307cc/307cc33e839fa693c1a0c57a17424c8c74b62773" alt=""
第 9 关(点空格点绕过)
根据源码发现这关把我们之前的方式都过滤了
data:image/s3,"s3://crabby-images/440dd/440ddfd3f0f537099f8a6b86f4accd26ae4774b2" alt=""
我们可以在文件尾部加上点空格点(. .)就可以成功上传
data:image/s3,"s3://crabby-images/954b7/954b799fedd840c0b7d2553620376b1c881e880c" alt=""
data:image/s3,"s3://crabby-images/1f5ef/1f5efbfff8d03555d7a0b3b5eec1340130d98515" alt=""
第 10 关(重复写绕过)
根据源码发现只有一个黑名单验证
data:image/s3,"s3://crabby-images/05483/05483f6a0b40c69efaf071aa095516858ee63d8d" alt=""
我们只要把文件后缀改成.pphphp就可以成功上传
第 11 关(get 00截断绕过)
这里我们使用 ctfhub 技能书中的 web 的文件上传的 00 截断为例子
第 12 (post 00截断绕过)
本关采用的是POST型的%00,和11关一样,只需要将%00写在post请求包中
第 13 关(文件包含图片马绕过)
copy 6.png/b+1.php 3.png
data:image/s3,"s3://crabby-images/985c5/985c5fae60931762f753ecdedbcf18b68c4e6f1c" alt=""
data:image/s3,"s3://crabby-images/5bdb4/5bdb40b82c03ae2a669e7c8b9a366d22c0fff298" alt=""
把我们制作好的图片马上传,点击在信标签打开图片就可看到我们图片的名称
data:image/s3,"s3://crabby-images/158f1/158f1fc7d21ef263b0d91e7768c98384c935c194" alt=""
在靶场的文件中有一个include.php
data:image/s3,"s3://crabby-images/6e9e6/6e9e66c27a8291eca2ee00536d7ab2ee41e3ab82" alt=""
在include.php后面跟上参数和路径就能访问我们的图片马
data:image/s3,"s3://crabby-images/b376b/b376b2e66c647b62a9e7cd850881f2d12079b776" alt=""
第 14 关(文件包含图片马绕过)
直接上传我们的图片马
data:image/s3,"s3://crabby-images/80509/80509afa13fdaa18a2b9c85958fc9ffebbfd25a4" alt=""
第 15 关(文件包含图片马绕过)
十五关需要一个模块,在小皮里面打开就可
data:image/s3,"s3://crabby-images/99691/99691a572a4fc658d7a17b21259b4da99f74376a" alt=""
data:image/s3,"s3://crabby-images/79b3f/79b3fb6f22a3d7aa5ee87e03e54979458cf56d15" alt=""
直接传之前的图片马就行
第 16 关(文件包含二次渲染专用图绕过)
二次渲染+文件包含同13
第 17 关(抓包爆破条件竞争)
data:image/s3,"s3://crabby-images/62da3/62da38f5eb34ace5b674e171b8ce169d6f1a4f83" alt=""
第十七关会上传成功,但是成功后会检测文件是否符合规定,不符合规定的文件将被删除
因此我们可以利用php文件读写来爆破攻击
代码如下
<?php fputs(fopen('webshell.php','w'),'<?php @eval($_POST["cmd"])?>');?>
由于会删除我们上传的文件,我们可以一直爆破上传并访问上传的1.php文件来生成webshell.php文件
此时我们已经创建好了webshell.php文件
data:image/s3,"s3://crabby-images/65330/653308fdc62f2237f4af8810a0cfc010725cd0ef" alt=""
可以看到我们已经成功的过关
第 18 关(上传二次渲染的图片马 文件包含漏洞)
同16和13
第 19 关(文件名命名规范)
data:image/s3,"s3://crabby-images/e2fb6/e2fb60aeb2e20dc1159c6d30df2a20779d34e679" alt=""
第19关文件存在命名规范,我们选择上传1.php文件,将他命名为1.php.(这里是个点),即可上传成功