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

訪問http://your-ip:3000/即可查看到一個web頁面,其中引用到了文件/static/main.js,說明其存在靜態文件服務器。

抓包後把路徑改成/static/../../../a/../../../../etc/passwd即可

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章