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

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

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

一、漏洞描述

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

二、漏洞复现

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灵动标签同时调用头条(1级、2级)、推荐(1级、2级)方法1、同时调用头条(1级、2级)、推荐(1级、2级) [e:loop={0,10,3,0,'isgood=1 or firsttitle=1 orisgood=2 or firsttitle=2'}] <a href="<...

帝国CMS模板中随机调用文章信息

帝国CMS模板中随机调用文章信息

可以在生成标签的时候,标签参数中的排序参数用:’rand()’。引号不用。 比如: [ecmsinfo]2,10,32,0,0,2,0,”,’rand()’[/ecmsinfo] 但如果信息量很大的时候,比如上万后。严重影响生成速度。不建意使用。 如果确实要使用,可以用下面思路: 先用php随机出...

帝国cms模板内容页SQl调用当前TAG标签

帝国cms模板内容页SQl调用当前TAG标签

帝国cms内容页SQl方式调用当前TAG标签的方式 具体调用代码如下: <?php $fr=$empire->fetch1("select infotags from {$dbtbpre}ecms_news_data_{$navinfor[stb]} where id='$navinf...

帝国CMS自动审核发布信息文章的方法

帝国CMS自动审核发布信息文章的方法

当一个文章站大量采集内容,一次性全部发布完这一是不利于SEO的,也是容易作弊,所以从网上找了这个脚本稍作修改。分享给大家,其实也很简单,但比帝国自带的计划任务功能好的是,不用开启后台才运行,脚本放到服务器上后加入服务器的计划任务便可以每天定时审核发布信息。下面帝国cms模板网来告诉大家帝国CMS自动...

帝国cms搜索模板无缓存使用多个搜索模板

帝国cms搜索模板无缓存使用多个搜索模板

网站中用到两个甚至多个搜索模板,在搜索代码中除了会设置指定的模板id以外,还需要更改以下内容,目的就为了解决缓存问题,比如说,用户可能是在搜索“模板”图文列表后,再去搜“教程”,搜索列表显示的还是之前“模板”的搜索模板。提醒大家一定要先备份哟!教程如下: 将以下内容替换到/e/search/resu...

帝国CMS灵动标签调用指定时间段的信息

帝国CMS灵动标签调用指定时间段的信息

帝国CMS灵动标签怎么调用指定时间段的信息呢? 1、某天发布的文章: [e:loop={'news',10,18,0,'newstime>='.to_time('2010-11-11 00:00:01').' and newstime<='.to_time('2010-11-11 23...