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

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

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

一、漏洞描述

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

二、漏洞复现

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://www.blueboss.cn/p/719.shtml

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

帝国CMS后台登录成功又提示您还未登录

帝国CMS后台登录成功又提示您还未登录

帝国CMS登录后台,帝国CMS后台登录显示“登录成功”后,马上跳转显示“您还未登录。那么怎么解决呢?其实很简单; 出现此问题是目录权限问题 /e/data/adminlogin 目录权限不可写导致,请将此目录权限设置为777权限即可解决 OK,搞定!...

帝国CMS动态页支持栏目导航标签循环子栏目数据标签万能标签的调用

帝国CMS动态页支持栏目导航标签循环子栏目数据标签万能标签的调用

分享一种利用JS来实现支持栏目导航标签,万能标签,循环子栏目数据标签的方法。   第一步:在【模板】下面增加标签模板,标签模板内容如下:   页面模板内容(*): [!--empirenews.listtemp--]<!--list.var1-->[!--empirenews.list...

帝国CMS多值字段如何调用多值字段最新增加的一行内容

帝国CMS多值字段如何调用多值字段最新增加的一行内容

帝国cms模板里面的多值字段怎么调用呢? 多值字段调用如下: <?php $morefr=explode('||||||',$navinfor[字段名]); $mfcount=count($morefr); for($mfi=0;$mfi<$mfcount;$mfi++) { $mor...

帝国cms信息反馈开启验证码

帝国cms信息反馈开启验证码

1、后台-系统设置-系统参数设置-信息设置-反馈验证码(后面点开启) 2、信息反馈本身并无放置验证码代码,所先复制评论的验证码代码,后台-模板-评论列表模板-管理评论模板-修改-复制其中的验证码代码 代码如下: 验证码:<input name="key" type="text" size=...

帝国CMS模板中不同会员组显示不同内容

帝国CMS模板中不同会员组显示不同内容

帝国cms模板里面不同会员组显示不同内容怎么实现? 具体调用代码如下: <?php  if(getcvar('mlgroupid')<1)  {  ?>  //游客看到的内容  <?php  }  elseif(getcvar('mlgroupid')==1)  {  ?&...

帝国CMS留言板增加字段

帝国CMS留言板增加字段

帝国CMS留言板增加字段的方法 整理了下我的修改步骤(实现留言板增加qq、留言主题字段): 1、进入phpmyadmin后台,在数据库enewsgbook表(留言板数据表)中增加字段, 比如: qq、theme,  2、打开e\enews\gbookfun.php, 1、在13行左右的地方插入下面代...