利用配置错误的IAM策略窃取云函数访问令牌[GCP]

利用配置错误的IAM策略窃取云函数访问令牌[GCP]

身份与访问管理(IAM)策略配置错误如何导致Google Cloud中云函数访问令牌暴露和利用

在身份与访问管理(IAM)中,策略是一组规则,通过指定谁可以对哪些资源执行什么操作来定义访问控制。这些策略帮助管理员在环境中有效管理权限。

在Google Cloud Platform(GCP)中,策略通常包含三个主要组件:

  • 成员 - 通常是用户、服务账户和群组
  • 角色/权限 - 定义成员可以对特定资源执行的操作
  • 资源 - 这些策略应用的实际资产,如项目、云函数、存储桶、计算实例等

这些IAM策略中的任何配置错误如果允许意外访问,都可能导致安全风险。

在本博客文章中,我们将探讨一个场景:云函数IAM策略中的配置错误使攻击者能够窃取服务账户的访问令牌。该场景假设我们已经获得了GCP环境的访问权限。

理解云函数

GCP中的云函数类似于AWS Lambda,是由事件驱动操作触发执行的代码块。这些无服务器函数允许开发人员自动化流程,如调整图像大小、将文件上传到存储桶或在数据库记录被修改时发送通知。

我们可以通过不同方式触发云函数 - 直接使用gcloud functions call命令调用它们,使用Google Cloud Console,或向函数的URL发送GET或POST请求。

更新云函数的IAM策略变更

过去,任何被分配了cloudfunctions.admin或cloudfunctions.developer角色的用户或服务账户都能直接对函数进行更改。然而,Google更改了IAM策略,现在只有服务账户可以更新函数。

要更新函数:

  • 服务账户必须具有cloudfunctions.developer角色或cloudfunctions.admin角色
  • 如果用户想要更新函数,他们需要iam.serviceAccountUser角色或iam.serviceAccounts.actAs权限

所需工具

对于此实验,我们需要在测试机器上安装gcloud CLI。

利用步骤

在这个实验场景中,我们使用名为auditor-srv-acc的服务账户获得了立足点。其中一个可访问的函数运行代码,当调用时,会检索绑定到该函数的服务账户的访问令牌,允许我们横向移动到另一个账户。

1. 使用服务账户进行身份验证

首先使用gcloud auth命令进行身份验证,并提供服务账户JSON文件进行认证。

bash 复制代码
gcloud auth activate-service-account --key-file [JSON密钥文件]

2. 枚举IAM策略

访问环境后,我们开始枚举过程,检查分配给项目的IAM策略。

bash 复制代码
gcloud projects get-iam-policy [项目名称]

3. 检查自定义角色的权限

由于自定义角色带有特定的权限集,我们需要检查我们被分配了哪些权限。

bash 复制代码
gcloud iam roles describe toub2726 --project [项目名称]

4. 列出可用函数

接下来,我们检查可访问的资源,如函数。

bash 复制代码
gcloud functions list

5. 查看函数详细信息

获得可用函数列表后,我们可以获取每个函数的更多详细信息。

bash 复制代码
gcloud functions describe [函数名称]

6. 检查每个函数的IAM策略

接下来,我们检查每个可访问函数的IAM策略。

bash 复制代码
gcloud functions get-iam-policy [函数名称]

7. 调用函数

此时,我们可以通过向函数元数据中找到的URL发送GET或POST请求来触发函数。

bash 复制代码
curl -X POST "https://函数URL" -H "Content-Type: application/json" -d '{}'

8. 验证访问令牌

获得访问令牌后,我们可以通过访问以下URL并粘贴访问令牌来验证其有效性。

bash 复制代码
https://www.googleapis.com/oauth2/v1/tokeninfo?access_token=[访问令牌]

缓解策略

  • 重新配置IAM策略,移除allUsers和allAuthenticatedUsers调用函数的权限
  • 通过审查函数代码确保访问令牌永远不会被记录、打印或以任何方式暴露,防止云函数暴露访问令牌
  • 如果需要访问令牌,使用密钥管理器安全地存储和检索它们

如今天的文章所示,资源级别(如云函数)的错误配置IAM策略允许所有用户调用函数。这种错误配置使我们能够运行函数并检索访问令牌,即使我们用于身份验证的服务账户只有具有有限权限的查看者角色。

相关推荐
IT_陈寒3 分钟前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端
用户69371750013845 分钟前
不卷AI速度,我卷自己的从容——北京程序员手记
android·前端·人工智能
love530love9 分钟前
不用聊天软件 OpenClaw 手机浏览器远程访问控制:Tailscale 配置、设备配对与常见问题全解
人工智能·windows·python·智能手机·tailscale·openclaw·远程访问控制
lifallen17 分钟前
从零推导多 Agent 协作网络 (Flow Agent)
人工智能·语言模型
guoji778820 分钟前
2026年Gemini 3 Pro vs 豆包2.0深度评测:海外顶流与国产黑马谁更强?
大数据·人工智能·架构
树獭叔叔22 分钟前
从RLHF到PPO:让AI学会说人话
后端·aigc·openai
沸点小助手23 分钟前
「AI 能力提升场」沸点获奖名单公示|本周互动话题上新🎊
aigc·openai·vibecoding
NAGNIP25 分钟前
一文搞懂深度学习中的损失函数设计!
人工智能·算法
千桐科技27 分钟前
大模型幻觉难解?2026深度解析:知识图谱如何成为LLM落地的“刚需”与高薪新赛道
人工智能·大模型·llm·知识图谱·大模型幻觉·qknow·行业深度ai应用
Hello.Reader28 分钟前
词语没有位置感?用“音乐节拍“给 Transformer 装上时钟——Positional Encoding 图解
人工智能·深度学习·transformer