首页
/ EntraGoat权限升级深度解析:从Graph权限滥用到全局管理员接管的安全风险

EntraGoat权限升级深度解析:从Graph权限滥用到全局管理员接管的安全风险

2026-04-12 09:44:12作者:韦蓉瑛

风险场景解构

在企业身份管理体系中,Microsoft Entra ID(原Azure AD)的权限配置不当往往成为安全漏洞的温床。EntraGoat场景2通过模拟证书泄露事件,揭示了从普通用户权限到全局管理员权限的完整升级路径。该场景核心围绕"Corporate Finance Analytics"服务主体的证书泄露展开,攻击者利用服务主体配置的过度权限,构建了一条清晰的权限提升链条,最终实现对整个租户的完全控制。

漏洞原理分析

核心权限矩阵关系

权限标识 权限名称 风险等级 权限传导路径
9e3f62cf-33a7-4b62-ba47-36384f22c8de AppRoleAssignment.ReadWrite.All ⚠️ 高风险 允许管理服务主体的角色分配
749f88d5-cbae-40b8-bcfc-e573ddc772fa RoleManagement.ReadWrite.Directory ⚠️ 高风险 允许管理目录角色分配
62e90394-69f5-4237-9190-012177145e10 全局管理员 ⚠️ 极高风险 拥有租户全部管理权限

权限传导流程图

EntraGoat安全审计:权限传导流程图

上图展示了完整的权限升级流程:攻击者(jennifer.clark)首先通过泄露的证书认证为"Corporate Finance Analytics"服务主体(步骤1),利用AppRoleAssignment.ReadWrite.All权限为自己授予RoleManagement.ReadWrite.Directory权限(步骤2),通过断开重连刷新令牌(步骤3),进而分配全局管理员角色(步骤4),最终实现对管理员账户(EntraGoat-admin-s2)的密码重置(步骤5)。

防御策略体系

预防阶段:权限最小化配置

  1. 实施权限粒度控制:严格遵循最小权限原则,为服务主体仅分配完成工作所需的最低权限
  2. 证书生命周期管理:建立证书申领、使用、轮换和撤销的全流程管理机制
  3. 敏感权限审计:对AppRoleAssignment.ReadWrite.All等高危权限实施特殊审批流程

检测阶段:异常行为监控

  1. 权限变更告警:配置RoleManagement.ReadWrite.Directory权限分配的实时告警
  2. 服务主体行为基线:建立正常操作模式基线,识别异常的角色分配行为
  3. 证书使用审计:记录并分析证书的认证时间、地点和频率等信息

响应阶段:安全事件处置

  1. 权限快速撤销:建立紧急权限吊销流程,在检测到异常时立即移除可疑权限
  2. 证书轮换机制:制定证书紧急轮换方案,减少泄露证书的影响范围
  3. 安全事件复盘:建立事后分析机制,识别权限配置中的薄弱环节

实战演练建议

安全测试方法论

  1. 权限边界测试

    • 验证服务主体的权限范围是否符合最小权限原则
    • 测试跨服务主体的权限传导可能性
    • 模拟证书泄露场景下的权限利用路径
  2. 防御有效性验证

    • 测试权限变更告警的响应速度和准确性
    • 验证证书轮换流程的实际效果
    • 评估全局管理员账户的保护措施强度
  3. 演练环境搭建

    git clone https://gitcode.com/GitHub_Trending/en/EntraGoat
    cd EntraGoat/scenarios
    .\EntraGoat-Scenario2-Setup.ps1
    

安全合规声明

本文章所述技术仅用于授权的安全测试和教育目的。未经授权的系统访问和攻击行为均属违法,可能导致严重的法律后果。所有测试必须在拥有明确授权的环境中进行,并严格遵守组织的安全策略和适用法律法规。

延伸学习路径

  1. Microsoft Entra ID权限最佳实践文档
  2. Graph API权限参考指南
  3. 服务主体安全配置基准

社区贡献指引

欢迎通过项目Issue系统提交漏洞复现改进建议,或贡献新的防御策略案例。所有贡献需遵循项目的贡献指南,确保内容的准确性和安全性。建议贡献内容包括:权限配置审计脚本、异常行为检测规则、权限最小化配置模板等实用安全资源。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
docsdocs
暂无描述
Dockerfile
703
4.51 K
pytorchpytorch
Ascend Extension for PyTorch
Python
567
693
atomcodeatomcode
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get Started
Rust
547
98
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
957
955
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
411
338
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.6 K
940
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.08 K
566
AscendNPU-IRAscendNPU-IR
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
128
210
flutter_flutterflutter_flutter
暂无简介
Dart
948
235
Oohos_react_native
React Native鸿蒙化仓库
C++
340
387