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


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

    一、漏洞描述

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

    二、漏洞复现

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

      

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

      

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

      

      

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

      

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

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

    ‘;phpinfo();//

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

      

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

      

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

      

    8、构造特殊的payload getshell

      

    9、菜刀连接,成功getshell

      

    ----------------------------------------------------------------------------------------------------------------------

    参考资料:https://qclover.github.io/2018/10/10/EmpireCMS_V7.5%E7%9A%84%E4%B8%80%E6%AC%A1%E5%AE%A1%E8%AE%A1.html

  • 相关阅读:
    题解 P5320
    Codeforces 1500F
    三个 AGC D(AGC037D、AGC043D、AGC050D)
    Atcoder Regular Contst 084 D
    DG-基础知识点整理
    MySQL-数据恢复场景实验
    MySQL-查看Galera集群状态
    MySQL-运行日志切割
    MySQL-生产环境删除大表或大量binlog策略
    MySQL-基于(MySQL 5.7)NDB中启用共享权限表
  • 原文地址:https://www.cnblogs.com/yuzly/p/11369899.html
Copyright © 2020-2023  润新知