【漏洞复现】Node.js 目录穿越漏洞(CVE-2017-14849)

文章目录

1.1、漏洞描述

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

1.2、影响版本

  • Node.js 8.5.0 + Express 3.19.0-3.21.2

  • Node.js 8.5.0 + Express 4.11.0-4.15.5

1.3、漏洞复现

1、基础环境

Path:Vulhub/node/CVE-2017-14849


启动测试环境:

bash 复制代码
sudo docker-compose build
sudo docker-compose up -d

访问http://your-ip:{3000}/即可看到

2、漏洞验证

验证URL:/static/../../../a/../../../../etc/passwd

抓包修改请求地址

3、漏洞分析
js 复制代码
const express = require('express')
const app = express()
const path = require('path')
 
app.get('/', (req, res) => {
    res.send(`<html>
                <head>
                    <meta charset="utf-8">
                    <title>Hello vulhub!</title>
                </head>
                <body>
                    <div id="app">
                        <input v-model="name">
                        <p>Hello {{ name }}</p>
                    </div>
                <script src="//cdn.bootcss.com/vue/2.4.4/vue.min.js"></script>
                <script src="/static/main.js"></script>
                </body>
            </html>`)
})
 
app.use('/static', express.static(path.join(__dirname, 'static'))); //设置静态文件目录
 
app.listen(3000, () => console.log('Example app listening on port 3000!'))

static/main.js被引用源码

js 复制代码
var app = new Vue({
    el: '#app',
    data: {
        name: 'Vulhub'
    }
})

1.4、参考

相关推荐
OpenTiny社区2 小时前
Node.js 技术原理分析系列 4—— 使用 Chrome DevTools 分析 Node.js 性能问题
前端·开源·node.js·opentiny
huangfuyk2 小时前
使用Node.js从零搭建DeepSeek本地部署(Express框架、Ollama)
node.js·express·ollama·deepseek
华洛6 小时前
老板要求接入DeepSeek,哪家提供的服务强?
前端·javascript·node.js
菜鸟码农_Shi6 小时前
《NestJS vs Express:哪个更适合现代 Web 开发?》
node.js
墨菲斯托8887 小时前
Node.js原型链污染
前端·javascript·node.js
前端双越老师8 小时前
【万字总结】2025 前端+大前端+全栈 知识体系(下)
vue.js·react.js·node.js
小周同学:21 小时前
npm : 无法加载文件 C:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本。
前端·npm·node.js
恒星漫游者1 天前
Node.js连接池配置的五个隐形陷阱与防御体系:从创业公司血泪史说起
node.js
怒放的生命19911 天前
前端打包优化相关 Webpack
前端·webpack·node.js
以码平川1 天前
Node项目中配置文件的由来
node.js·es6