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

文章目录

  • [Node.js 目录穿越漏洞(CVE-2017-14849)](#Node.js 目录穿越漏洞(CVE-2017-14849))
    • [1. 漏洞原理](#1. 漏洞原理)
    • [2. 漏洞复现](#2. 漏洞复现)
    • [3. 漏洞验证](#3. 漏洞验证)
    • [4. 漏洞分析](#4. 漏洞分析)

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

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

影响版本

  • Node.js 8.5.0 + Express 3.19.0-3.21.2

  • Node.js 8.5.0 + Express 4.11.0-4.15.5

2. 漏洞复现

Path:Vulhub/node/CVE-2017-14849

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

3. 漏洞验证

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

抓包修改请求地址

4. 漏洞分析

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'
    }
})
相关推荐
book123_0_9917 小时前
node.js+npm的环境配置以及添加镜像(保姆级教程)
arcgis·npm·node.js
San30.17 小时前
手写 Mini Cursor:基于 Node.js 与 LangChain 的开发实战
人工智能·langchain·node.js·agent
好家伙VCC18 小时前
# Deno框架实战:从零搭建一个安全、高效的Node.js替代项目 在现代
java·python·安全·node.js
青春男大18 小时前
Node.js快速上手
node.js
猫头虎-前端技术18 小时前
这个项目需要Node 16,那个项目需要Node 18:如何解决多项目Node.js版本管理问题
前端·javascript·chrome·typescript·node.js·json·firefox
智能工业品检测-奇妙智能18 小时前
快速直播:Node.js + FFmpeg + flv.js 全栈实战
javascript·ffmpeg·node.js
minglie118 小时前
飞书聊天机器人事件回调测试
node.js·飞书
Less^_^19 小时前
Node.js 解构赋值快速入门
node.js
wind5201 天前
nodejs多版本管理工具nvm
node.js
白中白121381 天前
Node.js系列
node.js