终究没有人在意一家民营企业的生死

去泰国看了一场“成人秀”,画面尴尬到让人窒息.....

【少儿禁】马建《亮出你的舌苔或空空荡荡》

网友建议:远离举报者李X夫!

网曝黑人留学生侮辱中国女生是“母狗”,网友愤慨:不欢迎洋垃圾

生成图片,分享到微信朋友圈

自由微信安卓APP发布,立即下载! | 提交文章网址
查看原文

Node.js 目录穿越漏洞(CVE-2017-14849)

Bruce-Wang 黑白之道 2020-11-07


CVE-2017-14849是Node.js和Express共同导致的一个目录穿越漏洞,可以通过此漏洞读取任意文件。


原因是 Node.js 8.5.0 对目录进行`normalize`操作时出现了逻辑错误,导致向上层跳跃的时候(如`../../../../../../etc/passwd`),在中间位置增加`foo/../`(如`../../../foo/../../../../etc/passwd`),即可使`normalize`返回`/etc/passwd`,但实际上正确结果应该是`../../../../../../etc/passwd`。

express这类web框架,通常会提供了静态文件服务器的功能,这些功能依赖于`normalize`函数。比如,express在判断path是否超出静态目录范围时,就用到了`normalize`函数,上述BUG导致`normalize`函数返回错误结果导致绕过了检查,造成任意文件读取漏洞。

当然,`normalize`的BUG可以影响的绝非仅有express,更有待深入挖掘。不过因为这个BUG是node 8.5.0 中引入的,在 8.6 中就进行了修复,所以影响范围有限。

访问`http://192.168.28.4:3000`即可查看到一个web页面,其中引用到了文件`/static/main.js`,说明其存在静态文件服务器。


payload:  /static/../../../a/../../../../etc/passwd

使用BurpSuite发送Payload,可以看到成功返回了/etc/password的内容




推荐文章++++

*phpmyadmin 4.8.1 远程文件包含漏洞(CVE-2018-12613)

*PostgreSQL 提权漏洞(CVE-2018-1058)

*Elasticsearch写入webshell漏洞(WooYun-2015-110216)


    文章有问题?点此查看未经处理的缓存