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

漏洞分析

原因是 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 中就进行了修复,所以影响范围有限。

影响版本

Node.js 8.5.0 + Express 3.19.0-3.21.2
Node.js 8.5.0 + Express 4.11.0-4.15.5

环境搭建

cd vulhub/node/CVE-2017-14849

docker-compose build && docker-compose up -d

Node.js 目录穿越漏洞(CVE-2017-14849)_第1张图片

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

Node.js 目录穿越漏洞(CVE-2017-14849)_第2张图片

抓包后把路径改成/static/../../../a/../../../../etc/passwd即可

Node.js 目录穿越漏洞(CVE-2017-14849)_第3张图片

你可能感兴趣的:(CVE-2017-14849)