当前位置:首页 > 文章 > 帝国CMS > 正文内容

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

3年前 (2022-10-22)帝国CMS6267

一、漏洞描述

该漏洞是由于安装程序时没有对用户的输入做严格过滤,导致用户输入的可控参数被写入配置文件,造成任意代码执行漏洞。

二、漏洞复现

1、漏洞出现位置如下图,phome_表前缀没有被严格过滤导致攻击者构造恶意的代码

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

2、定位漏洞出现的位置,发现在/e/install/index.php,下图可以看到表名前缀phome_,将获取表名前缀交给了mydbtbpre参数。

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

3、全文搜索,$mydbtbpre,然后跟进参数传递,发现将用户前端输入的表前缀替换掉后带入了sql语句进行表的创建,期间并没有对前端传入的数据做严格的过滤

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

4、创建表的同时将配置数据和可以由用户控制的表前缀一起写入到config.php配置文件

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

5、通过对整个install过程的代码分析,可以发现没有对用户数据进行过滤,导致配置文件代码写入。

5.1、burp对漏洞存在页面进行抓包,修改phome参数的值,构造payload,payload如下:

‘;phpinfo();//

5.2、在burp中的phome参数的值中输入特殊构造的payload

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

6、查看config.php配置文件,发现成功写入配置文件

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

7、再次访问安装结束的页面, http://192.168.10.171/empirecms/e/install/index.php?enews=moddata&f=4&ok=1&defaultdata=1

  帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

8、构造特殊的payload getshell

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

9、菜刀连接,成功getshell

帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析

 

扫描二维码推送至手机访问。

版权声明:本文由蓝博发布,如需转载请注明出处。

本文链接:https://blueboss.cn/p/719.shtml

“帝国CMS(EmpireCMS)v7.5配置文件写入漏洞/挂马分析” 的相关文章

帝国cms内容页正文附件下载的调用代码

帝国cms内容页正文附件下载的调用代码

帝国cms内容页正文附件下载的调用代码 [e:loop={"select * from phome_enewsfile_1 where classid='$navinfor[classid]' and id='$navinfor[id]' order by id desc",0,24,0,'','...

帝国CMS上传生成的随机文件名前面增加自定义前缀

帝国CMS上传生成的随机文件名前面增加自定义前缀

帝国CMS上传生成的随机文件名前面怎么实现增加自定义前缀呢?如何实现?帝国CMS默认上传文件后生成一个32位的随机名称,今天教大家的方法可以在这个32位的随机名称前增加固定名称。 比如,增加 lexiw_ 那么生成后的文件名称就是: lexiw_3445645iuiu567567u5pou5675...

帝国CMS灵动标签调用当前栏目下子栏目列表

帝国CMS灵动标签调用当前栏目下子栏目列表

灵动标签调用当前栏目下子栏目,支持栏目自定义排序。下面帝国cms模板网就来告诉大家: [e:loop={"select classname,classpath,classid from phome_enewsclass where bclassid='$GLOBALS[navclassid]' a...

帝国CMS专题页面调用当前专题页面地址

帝国CMS专题页面调用当前专题页面地址

当前专题页面地址 <?=$public_r[newsurl]?><?=$class_zr[$GLOBALS[navclassid]][ztpath]?> <?=$public_r[newsurl]?>网站地址 <?=$class_zr[$GLOBALS[n...

帝国cms后台出现Failtoconnectftphost!

帝国cms后台出现Failtoconnectftphost!

帝国cms后台创建新栏目、上传附件会出现错误:Fail to connect ftp host! 后台备份数据库也备份了出现500错误 解决方式 后台 系统设置-ftp设置-php运行安全模式 取消就可以了...

帝国CMS列表页判断是否有标题图片没有则显示指定的图片

帝国CMS列表页判断是否有标题图片没有则显示指定的图片

帝国CMS列表页模板里面怎么判断文章是否有标题图片,如果没有图片就调用显示默认或者指定的一张图片!   第一种方法、用php判断:   ①、复制以下代码带到“列表内容模板” if(empty($r[titlepic])) { $pic=''; } else { $pic='<img src=...