问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

mongo-express 远程代码执行漏洞分析

发布网友 发布时间:2024-10-05 01:51

我来回答

1个回答

热心网友 时间:2024-10-23 03:29

作者:4ct10n合天智汇

搭建调试环境,调试 CVE-2019-10758 漏洞,学习nodejs 沙箱绕过,以及nodejs 远程调试。目前网上关于该漏洞的基于docker的远程调试分析写的很泛,本文从初学者角度分析调试漏洞成因,特别是在chrome浏览器调试nodejs上花了点篇幅。

0x01 认识 mongo-express

mongo-express是一个MongoDB的Admin Web管理界面,使用NodeJS、Express、Bootstrap3编写而成。目前mongo-express应该是Github上Star最多的MongoDB admin管理界面。部署方便,使用简单,成为了很多人管理mongo的选择。

0x02 调试环境搭建0x1 启动docker服务

阅读官方GitHub的安全公告,我们发现漏洞影响0.54.0以下的所有版本。选择以0.49为例进行测试,由于此漏洞环境还需要MongoDB数据库,我们可以通过执行以下docker命令进行快速搭建:

docker run --name test -d mongo:3.2

docker run -d -p 8081:8081 --link test:mongo mongo-express:0.49

查看日志,确认连接成功。

0x2 开启nodejs调试选项

这里需要个技巧,如果要调试nodejs 需要在启动的时候加上 --inspect 参数。 在docker启动脚本做以下修改

docker restart 183

利用docker exec -it 183 bash连接docker查看debug服务是否开启

如上图中开启9229端口即可。只需要外面主机能够连接访问9229端口就可以利用chrome插件进行调试,可以用frp将端口转发出来,或者利用docker -p 9229:9229参数做处理。

0x3 Chrome DevTools

利用chrome 插件可以实现像调试javascript脚本一样调试nodejs,操作起来也是很方便。

首先下载debug插件

在chrome打开about:inspect chrome devtools在2016年5月就已经支持Nodejs的调试,点击Open dedicated DevTools for Node

配置连接地址和端口

接下来就像调试js一样了

发送一个测试包,该路由分支可以断下,接下来就开始调试本次漏洞了。

0x03 漏洞调试及原理分析

本次调试的漏洞原理比较简单,核心漏洞是命令拼接,这是一种最简单的漏洞形式,但是利用起来需要点功夫,因为需要绕过沙箱VM,好在nodejs的vm绕过有过研究基础。多的不说,直接看最后的漏洞代码

string为toBSON的参数,在MongoDB中BSON是一种常见的数据格式,与JSON是近亲,但是和JSON的数据格式有很多区别,而然在mongo-express中的所有和BSON相关的操作,如新建一个文档(类似其他数据库的插入操作)都需要通过toBSON()函数。

例如下面操作

当代码流程走到bson.toBSON时会触发eval函数,因为nodejs可以作为后端语言所以该eval函数是在服务器端运行,可以造成命令注入,对系统产生危害。

由代码溯源分析得到,toBSON的参数string是req.body中的document,因此这一部分我们可控。可以发现vm.runInNewContext函数,这是一个虚拟沙箱。因此们下一节分析怎么绕过沙箱防护。

0x04 nodejs 沙箱绕过

沙箱是一个能够安全执行不受信任的代码,且不影响外部实际代码的独立环境。在沙箱里代码执行往往会被*。VM模块提供在VM虚拟机上下文中编译运行代码的API。使用VM模块可以在沙箱环境中运行代码。运行的代码使用不同的V8上下文,也就是它的全局变量不同于其他代码。但是沙箱里的代码仍然可以访问Node进程。我们经常使用该方法去绕过。

0x1 现象

vm.js

可以看到this.process.env获取到了nodejs进程的信息,这说明完全可以切回主程序去执行系统命令。

0x2 解释

在javascript中this指向它所属的对象,所以我们使用它时就已经指向了一个VM上下文之外的对象。那么访问this的 .constructor 就返回 Object Constructor ,访问 Object Constructor 的 .constructor 返回 Function constructor 。 Function constructor 就像javascript里的最高函数它允许全局访问。Function constructor允许从字符串生成函数,从而执行任意代码。所以我们可以利用它返回主进程。之后我们就能用它来访问主进程,然后进行RCE。

同理vm2 函数也可以绕过,这里还是参照原文进行学习吧 pwnisher.gitlab.io/node...

0x05 漏洞修补

这里放两个图可以说明一切,利用mongo-query-parser 去解析BSON数据,直接从根源替换。

0x06 参考文献

segmentfault.com/a/1190...

nodejs.org/en/docs/guid...

mntn0x.github.io/2020/0...

声明:笔者初衷用于分享与普及网络知识,若读者因此作出任何危害网络安全行为后果自负,与合天智汇及原作者无关!
mongo-express 远程代码执行漏洞分析

本次调试的漏洞原理比较简单,核心漏洞是命令拼接,这是一种最简单的漏洞形式,但是利用起来需要点功夫,因为需要绕过沙箱VM,好在nodejs的vm绕过有过研究基础。多的不说,直接看最后的漏洞代码 string为toBSON的参数,在MongoDB中BSON是一种常见的数据格式,与JSON是近亲,但是和JSON的数据格式有很多区别...

web前端开发需要哪些技能

这部分需要掌握ES6的基础用法和兼容性;掌握ES6的核心语法;使用ES6实现前端模块化开发。使用Webpack模块打包器;使用Node.js进行Web服务端开发;掌握JavaScript异步编程模型;掌握JavaScript模块化编程方式;使用Node.js操作MongoDB数据库;独立开发基于后台接口的动态网站、Ajax数据交互的项目;独立完成企业网站从前台到...

命令执行漏洞和代码执行漏洞 远程代码执行漏洞 远程代码执行漏洞详解 mongo express 代码执行漏洞 漏洞代码 漏洞代码详解 20位漏洞代码 代码id漏洞
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
文件密使无法恢复解密,请高手帮忙 加密文件打不开了,请教高手..急需用那些文件 跪求电脑高手帮忙解决文件加密问题,我把所有积分给他。 我的优盘是联想的,用自带的加密软件加密后,忘了密码,请教高手,怎么解密... pe pb是什么 抱着柴火去火跟前猜谜语 关于租用办公室房产税如何计算与缴纳的问题 一个人抱着柴火前方是火是打一成语的谜语 ...前男友跟别的女人抱一起的时候,放的背景纯音乐出自哪里 ...从前男友家出来后被阿苏接上车,在车上的背景音乐是什么,在哪里有下... 过敏性哮喘吃什么水果 mx4 值不值的入手 或者其他手机更好 求推荐 小儿过敏性哮喘吃什么水果 ...Spring​ Data MongoDB SpEL表达式注入漏洞 微信朋友圈怎样设置评论仅彼此可见 mx4是不是4g手机 朋友圈的评论设置为好友可见,怎么设置? 翠城馨园323号楼位置 北京 魅族mx4设置—关于手机—型号:mx4是什么意思? CVE-2022-22980 Spring​ Data MongoDB SpEL表达式注入漏洞分析 唯见长江天际流&惟见长江天际流 中到底是那个(wéi) 惟见长江天际流哪个唯 明基投影仪优缺点 明基 投影仪怎么样 煮茶有讲究,什么茶适合煮?怎样煮才好喝? 什么样的人不适合喝羊奶? 茶识|煮茶是用冷水还是热水呢 喝茶,煮还是不煮?哪些茶类适合煮饮? 猫为什么不能喝牛奶但羊奶可以喝 能率热水器跳90故障原因 儿童保险箱如何换密码 面积大如何取暖 过敏性哮喘吃什么水果最好 MX4手机怎么样 夸克网盘的链接怎么用? 玩具保险箱怎么改密码 魅族MX4这款手机怎么样 求科普 什么是夸克链接,怎么用呢? 魅族隐私政策怎么回事 夸克浏览器怎么解析磁力链接 保险箱如何重置密码 夸克怎么转存资源? 阴阳师手游赤舌御魂最强搭配推荐[图]-手游攻略-游戏鸟手游网 华为nova微信消息不及时提醒怎么办? 冬天制热较好的空调品牌有哪些呢? 《民事诉讼法》和《刑事诉讼法》的区别 希腊奥运火种在哪 国防科技大学和清华北大谁好啊? 奥运火种在哪里采集 奥运会火种在哪里采集