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

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

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

一、漏洞描述

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

二、漏洞复现

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/message/index.php 提示文字要改语言包 e/data/language/gb/pub/q_message.php OK!搞定!大家赶紧去试试吧!...

帝国CMS自定义页面用PHP获取页面ID页面名称标题关键词描述内容等变量

帝国CMS自定义页面用PHP获取页面ID页面名称标题关键词描述内容等变量

帝国CMS自定义页面模板里面怎么调用页面名称,页面标题,关键词,描述,内容的方法! 方法一、获取自定义页面的页面ID,用以下代码: <?php    $pageid=str_replace("page","",$classid); ?> 在帝国CMS中,自定义页面的页面ID好像是唯一开...

帝国CMS列表页调用副表字段

帝国CMS列表页调用副表字段

列表模板中要调用副表字段内容需要采用“list.var支持程序代码”。下面帝国cms模板网就来告诉大家: 下面以读取新闻副表中的newstext字段为例的list.var模板代码: $fr=$empire->fetch1("select newstext from {$dbtbpre}ecm...

帝国CMS内容页和会员中心怎么调用是否实名认证的会员

帝国CMS内容页和会员中心怎么调用是否实名认证的会员

帝国CMS7.5内容页和会员中心调用会员是否实名认证的的方法! 实现方法如下: 在会员中心页面里加上以下代码即可实现: <?php $userr=sys_ShowMemberInfo(0,''); ?> <?php if($userr[isern]==1) { ?> 已认...

帝国CMS广告JS防止被浏览器过滤拦截

帝国CMS广告JS防止被浏览器过滤拦截

帝国CMS广告JS防止被浏览器过滤的几种解决方法   方式一(修改源文件)   修改/e/admin/tool/ListAd.php   找到页面中//生成广告js这条   把下面的: $file="../../../d/js/acmsd/".$public_r[adfile].$adid.".j...

帝国CMS后台恢复数据库出错的问题

帝国CMS后台恢复数据库出错的问题

帝国CMS后台恢复数据库出现错误怎么办的解决方法,一起来看看吧: 在本地调试并备份好,上传服务器还原出现这样的问题 You have an error in your SQL syntax; check the manual that corresponds to your MySQL serve...