[upload-labs] 学习
2019-01-19 本文已影响92人
2mpossible
一个帮你总结所有类型的上传漏洞的靶场
Pass-01
- 在js中发现校验文件后缀的函数,我们添加php类型后在控制台更改然后上传shell
data:image/s3,"s3://crabby-images/a95db/a95db33adb1574f3e2f74434c762f41c5079313e" alt=""
data:image/s3,"s3://crabby-images/dc1e4/dc1e4c145c9ce0a96a80ab649692ca8a0a903125" alt=""
data:image/s3,"s3://crabby-images/0b563/0b563a2aea72eee52d0a8dcc38b8fbd6cbe55ca2" alt=""
- 上传shell之后在返回的数据中发现了shell的路径,然后用蚁剑连接即可
data:image/s3,"s3://crabby-images/15ee2/15ee27d2f479ef4123f0a70b88d57137c5b7bbdc" alt=""
data:image/s3,"s3://crabby-images/6258c/6258cb127081f79b4621209363ce6d1d67fd7925" alt=""
Pass-02
- 这关是服务器验证,首先试了php后缀,当然是不行的,然后继续试了1.php.jpg是可以上传的,1.php.asd是不可以上传的,所以可以知道是白名单绕过,然后没思路看了提示和源码发现是检验了数据包的content-type,所以上传php的时候抓包修改content-type为image/jpeg来绕过上传即可
data:image/s3,"s3://crabby-images/977ab/977ab1df2ab49402f15921a6af185d222780cc46" alt=""
data:image/s3,"s3://crabby-images/4e5b4/4e5b41f3b0355745f5a476a527025df8739557c8" alt=""
Pass-03
- 上传php的时候有个很明显的黑名单限制提示,尝试使用php3,phtml绕过,最后phtml成功绕过并解析
data:image/s3,"s3://crabby-images/b526d/b526de6217072cbaf07ab621f09c7773c19afbcd" alt=""
data:image/s3,"s3://crabby-images/4e17b/4e17b9190c86e85d8b851ab0cbcc67a6749bdbb4" alt=""
Pass-04
-
不能上传php,但能上传php.jpg,php.asd,说明是黑名单限制,但是php3,phtml都被限制了,查看提示几乎所有可以绕过的后缀名都被限制了,但是唯独没有.htaccess,可以先上传一个.htaccess让所有文件解析为php,然后再上传一个图片马
-
htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置。通过htaccess文件,可以帮我们实现:网页301重定向、自定义404错误页面、改变文件扩展名、允许/阻止特定的用户或者目录的访问、禁止目录列表、配置默认文档等功能。
//.htaccess
SetHandler application/x-httpd-php
data:image/s3,"s3://crabby-images/7b70b/7b70b32b09c29831d6f73df2f1e68dcc27f37742" alt=""
data:image/s3,"s3://crabby-images/14485/144854b4af4985d31b4b62ec8ae8f8ced162008b" alt=""
Pass-05
- 不能上传php,.htaccess但能上传php.jpg,php.asd,说明是黑名单限制,查看源码发现与上一关少了统一大小写,所以用大小写绕过,上传phP文件绕过即可
data:image/s3,"s3://crabby-images/20637/20637f2a1827329926b966ecf9e24c090dce1f5a" alt=""
Pass-06
- 可以上传php.asd,黑名单限制,源码中没有去除空格所以可以上传.php 文件进行绕过
data:image/s3,"s3://crabby-images/42da8/42da800199ec36c7789a3609abd3983d833f41c6" alt=""
data:image/s3,"s3://crabby-images/c1bbd/c1bbd07efc8a7ba0f89a0fcb7906c9ec3859977d" alt=""
Pass-07
- 可以上传php.asd,黑名单限制,源码没有去除文件名最后的.号,windows特性会自动去掉后缀名中最后".",于是可以构造.php.来绕过上传
data:image/s3,"s3://crabby-images/c7897/c789741893d38af9b6d6e19e585c32aa7526c4ad" alt=""
Pass-08
- 可以上传php.asd,黑名单限制,没有去除文件名后缀的::$DATA, 同样可以利用 windows 特性, 在后缀添加::$DATA即可绕过
data:image/s3,"s3://crabby-images/1d705/1d705e737d77442f60df4263c7f7a1ecd3fc6544" alt=""
data:image/s3,"s3://crabby-images/07b2b/07b2b85c957953dc76250fa95c8f29a3adfce08d" alt=""
Pass-09
- 黑名单限制,咋一看好像可以绕过的都被限制了,但是仔细看最后拼接的文件名是处理后的文件名,所以可以上传"1.php. .",经过处理后的文件名就变成"1.php.",最后由于windows特性会将.自动去除来绕过
data:image/s3,"s3://crabby-images/8edd1/8edd11d68685a43e66394519548f35a889cd2328" alt=""
data:image/s3,"s3://crabby-images/39656/396564d924e6129798398301e5937d74380cedce" alt=""
data:image/s3,"s3://crabby-images/4e522/4e522cc0f4f8ff7d3b3944fe45c26a874a17d5ca" alt=""
Pass-10
- 黑名单过滤,上传时会去除php等字样,所以用双写绕过,构造.pphphp去除php后就变成.php
data:image/s3,"s3://crabby-images/300d3/300d3909b20db3df660855331603e47618038c50" alt=""
data:image/s3,"s3://crabby-images/7419f/7419fe6052a954a4eec3187d3f02adfe3aba62cf" alt=""
Pass-11
- 白名单校验,但是图片路径是拼接的,所以可以用%00截断
//%00截断适用条件
PHP 版本 < 5.3.4
php.ini 中 magic_quotes_gpc=off
data:image/s3,"s3://crabby-images/a7be7/a7be765bafce01fa8a60189572313905998def8a" alt=""
data:image/s3,"s3://crabby-images/920c5/920c5cd5bca951526414a2e415bc90cd25ac1d7d" alt=""
data:image/s3,"s3://crabby-images/ba5ad/ba5ad712ffdd8771b47bd40607afbd3cb18a82c9" alt=""
Pass-12
- 这题跟上一题的不同就是保存路径从 GET方法变成了POST方法,此时不能再使用%00截断, 因为%00截断在 GET 中被 url 解码之后是空字符,但是在 POST 中%00不会被 url 解码, 所以只能通过burpsuite修改hex值为00进行截断
data:image/s3,"s3://crabby-images/aefea/aefeafdd08f8f4e65e5d526197264053905b5948" alt=""
data:image/s3,"s3://crabby-images/54a4a/54a4ad21efcb2c22add36e0d6124bfff21906ebf" alt=""
data:image/s3,"s3://crabby-images/28606/28606b6f0a8f6bafa8ff11bb3508283aa1b56f5b" alt=""
data:image/s3,"s3://crabby-images/0d42d/0d42de78db1b769b8550fef59ab3e01132cd46b6" alt=""
Pass-13
- 题目要求上传图片马,源码是根据文件的前2个字节来判断文件类型,于是构造个图片马
data:image/s3,"s3://crabby-images/dadd1/dadd1075a4d6d865797b4862e9485f096494d040" alt=""
- 可以看到上传成功,后续利用就要配合文件包含了
data:image/s3,"s3://crabby-images/1b214/1b2141bdb47a591abccaa383379511a6d96395d7" alt=""
Pass-14
- 这里用了getimagesize()函数来检查图片,但是getimagesize也是根据文件头判断,所以跟上关一样就可以绕过了
data:image/s3,"s3://crabby-images/e7dea/e7dea2446f289ffcd1f134f87ac7d81c4dbffe42" alt=""
Pass-15
- 虽然换了exif_imagetype()检查,但是跟前两关一样就能绕过
data:image/s3,"s3://crabby-images/46fc0/46fc0f1c3577ec0f544e9d375a9f6a8df1a463bf" alt=""
Pass-16
-
发现上传即使没通过也会将图片存在upload目录下,后面发现是作者一开始的逻辑没写好,即使没通过if循环也会因为move_uploaded_file函数将图片马上传到upload目录,所以我又重新下载了一份作者修改后的版本
-
具体针对二次渲染的上传绕过可以看这篇文章upload-labs之pass 16详细分析,我试了下gif文件的绕过
-
修改没有二次渲染后没有变动的地方
data:image/s3,"s3://crabby-images/79691/79691b37be11f731824abdc998be294131a5f941" alt=""
- 利用文件包含成功执行php语句
data:image/s3,"s3://crabby-images/d4e00/d4e00f511b8ce17817feca0cc4e4bc2e18432be9" alt=""
- jpg文件我试了好几次发现都会将php语句破坏一点
Pass-17
- 查看源码发现存在条件竞争,在if判读不通过unlink文件之前已经用move_uploaded_file函数将文件上传到upload目录下,所以通过bp不断的上传weshell,然后在浏览器中不断的访问总能访问到未被unlink的webshell文件
data:image/s3,"s3://crabby-images/990d2/990d233015c6851b0ac95e4d78e2db9b91b6d1b5" alt=""
data:image/s3,"s3://crabby-images/a4b5f/a4b5f7e262afd364b13bcdcc0fbad138c0840da2" alt=""
Pass-18
- 上传图片马时也存在条件竞争,有可能会未重命名
data:image/s3,"s3://crabby-images/cbed7/cbed75b154dd682b224a571469d01195a6ecf137" alt=""
Pass-19
- move_uploaded_file()函数中的img_path是由post参数save_name控制的,因此可以在save_name利用00截断绕过
data:image/s3,"s3://crabby-images/444ce/444ce9610fb26c8d02340896c582ffd09416cb72" alt=""
data:image/s3,"s3://crabby-images/d5870/d587095b9b3f9e98b0c37a0177495313a2edc797" alt=""
- 上传成功
data:image/s3,"s3://crabby-images/1edfc/1edfcc5dbf09ad386fbdf89a29190c25791dec45" alt=""
data:image/s3,"s3://crabby-images/4f2d5/4f2d54f0bb07260c02e70c1488881251637f5abf" alt=""
Pass-20
$is_upload = false;
$msg = null;
if(!empty($_FILES['upload_file'])){
//检查MIME
$allow_type = array('image/jpeg','image/png','image/gif');
if(!in_array($_FILES['upload_file']['type'],$allow_type)){
$msg = "禁止上传该类型文件!";
}else{
//检查文件名
$file = empty($_POST['save_name']) ? $_FILES['upload_file']['name'] : $_POST['save_name'];
if (!is_array($file)) {
$file = explode('.', strtolower($file));
}
$ext = end($file);
$allow_suffix = array('jpg','png','gif');
if (!in_array($ext, $allow_suffix)) {
$msg = "禁止上传该后缀文件!";
}else{
$file_name = reset($file) . '.' . $file[count($file) - 1];
$temp_file = $_FILES['upload_file']['tmp_name'];
$img_path = UPLOAD_PATH . '/' .$file_name;
if (move_uploaded_file($temp_file, $img_path)) {
$msg = "文件上传成功!";
$is_upload = true;
} else {
$msg = "文件上传失败!";
}
}
}
}else{
$msg = "请选择要上传的文件!";
}
- 这里smi1e师傅教我如何绕过(我要做smi1e师傅的舔狗),首先end函数取所post参数数组中的最后一个值,$file_name = reset($file) . '.' . $file[count($file) - 1]我们可以post一个参数名为一个[0]一个[2],然后$file[count($file) - 1]就为空,$file_name最终就为reset($file)即$file[0],就可以绕过判断
data:image/s3,"s3://crabby-images/b36e9/b36e9f9e9baff9f5407be2b7e8571db85f8c880c" alt=""
data:image/s3,"s3://crabby-images/fee63/fee63d3816f0ab263ea205fa7274517de484e40f" alt=""
- 然后自动过滤.
data:image/s3,"s3://crabby-images/d7786/d778646285b30fe618130c0da67a57a22f579f24" alt=""