土法炼钢兴趣小组的算法知识备份

【Agent 身份与安全】Agent 身份谱系:从 API Key 到委托 Token

文章导航

分类入口
architecturesecurity
标签入口
#agent#oauth#token-exchange#rfc8693#delegation#jwt#iam#service-account

目录

LLM Agent 调用 Gmail、Slack、内部 API 时,「用谁的权限执行」没有统一答案。四代工程实践从 API KeyRFC 8693 Token Exchange,每一代解决一部分问题,也引入新的撤销与审计难题。本文从 IAM 系列 的 OAuth/OIDC 基础出发,聚焦 Agent 作为委托主体的身份表达——不重复 JWT 详解,只补 Agent 场景下的 claim 与坑。

核心问题:资源服务器(Resource Server, RS)收到一次 API 调用时,需要同时回答三个问题——谁在操作sub)、谁在代理act)、凭据是否仍有效exp + 吊销状态)。Gen4 委托模型把这三个问题写进 token 载荷;Gen2 把用户 refresh token 塞给 Agent 则三个问题全部失效。


一、四代身份模型全景

flowchart LR
  G1["Gen1 API Key"] --> G2["Gen2 用户 OAuth Token"]
  G2 --> G3["Gen3 Service Account"]
  G3 --> G4["Gen4 Token Exchange 委托"]
代际 凭证 绑定对象 撤销粒度 审计归因 典型问题
1 API Key / 静态 Secret 应用或 Agent 实例 轮换 Key,影响所有调用方 仅知「某 Key」 无用户归因;泄露即全权限
2 用户 access/refresh token 用户会话 用户 logout / refresh 吊销 sub,无法区分人与 Agent Agent 持长期 refresh;scope 过大
3 Service Account JWT / mTLS 工作负载 SA 禁用 仅 SA id,与用户意图脱钩 自动化强,委托语义弱
4 Delegated token(act claim) 用户→Agent 委托链 链式:用户 revoke → 委托 token 失效 sub + act.sub IdP 支持不一;实现复杂

生产目标:Gen4 语义 + Gen3 自动化——用户显式委托 Agent,Agent 运行时以 SA 证明自身(Gen3),经 Token Exchange 换短期用户委托 token(Gen4),RS 审计能回答「用户 U 的 Agent A 在 T 时刻调用了什么」。

1.1 Gen1:API Key 的残留场景

API Key 仍出现在:内部脚本、早期 SaaS 集成、无 OAuth 的 legacy API。对 Agent 而言,Gen1 意味着:

Gen1 acceptable 的唯一边界:Agent 只访问无用户上下文的全局资源(如公开天气 API)。一旦涉及用户邮件、文件、订单,必须升级到 Gen2 以上。

1.2 Gen2:用户 Token 直连的反模式

常见反模式:用户在 Web UI 完成 OIDC 授权码 + PKCE 后,前端把 refresh token 写入 Agent 进程的环境变量或本地文件。

风险 机制
撤销失效 用户 logout 后 refresh token 可能仍有效,直到 会话吊销 链完整执行
scope 膨胀 Agent 继承用户全部 scope,无法按任务缩小
归因混淆 RS 日志只有 sub=user,无法区分用户本人点击与 Agent 代操作
存储泄露 refresh token 落盘 = 长期凭据泄露面

Gen2 的正确子集:Agent Gateway 代表用户持有 refresh token(中心化存储、加密、HSM),Agent 进程永不接触 refresh token,只拿 Gateway 签发的短期 delegated access token。

1.3 Gen3:Service Account 的定位

Workload Identity 解决「这个 Pod/进程是谁」——SPIFFE ID、K8s ServiceAccount JWT、云 IAM 角色。Gen3 回答「代表哪个用户」。

正确组合:

Agent 进程 ──(SA JWT)──> 证明「我是 checkout-agent 工作负载」
         ──(Token Exchange)──> 换发「用户 U 委托的 read:orders scope token」

单独 Gen3:Agent 以 SA 调 API → 审计只有 SA,合规无法通过「用户授权」审查。

1.4 Gen4:委托 Token 的安全属性

RFC 8693 委托 token 应满足:

  1. 可验证:RS 用 JWKS 验签,检查 issaudexp
  2. 可归因:载荷含 sub(用户)与 act(Agent)。
  3. 可缩小scope ≤ 用户原授权 scope。
  4. 可撤销:用户会话吊销后,新 Exchange 拒绝;已有 token 靠短 TTL + 持续验证

二、RFC 8693 OAuth 2.0 Token Exchange

RFC 8693(A 级,2018-05 发布)定义 grant_type=urn:ietf:params:oauth:grant-type:token-exchange。它解决的核心问题:已有 token A,如何换发 token B,使 B 的权限 ≤ A,且表达代理关系

2.1 标准请求参数(RFC 8693 §2.1)

Token Exchange 请求发往 Authorization Server(AS)的 token endpoint,Content-Type 为 application/x-www-form-urlencoded

参数 REQUIRED 含义
grant_type 固定为 urn:ietf:params:oauth:grant-type:token-exchange
resource 目标 RS 标识(URI),用于 audience 约束
audience resource 类似,RFC 8707 Resource Indicators 语境
scope 请求的 scope,AS 不得发超 subject 原有权限的 scope
requested_token_type 期望输出 token 类型 URN
subject_token 条件 被代表的主体 token
subject_token_type 条件 subject token 的类型 URN
actor_token 条件 代理方 token
actor_token_type 条件 actor token 的类型 URN

subject-only exchange:只有 subject_token,无 actor_token——输出 token 的 sub 来自 subject,无 act claim。用于「换 audience / 缩小 scope」,非 Agent 委托。

actor + subject exchange:同时提交 actor_tokensubject_token——输出 token 含 act,表达「actor 代表 subject 行动」。Agent 委托的标准形态

2.2 Token 类型 URN(RFC 8693 §3)

URN 用途
urn:ietf:params:oauth:token-type:access_token OAuth 2.0 access token
urn:ietf:params:oauth:token-type:refresh_token Refresh token(部分 AS 禁止作为 subject)
urn:ietf:params:oauth:token-type:id_token OIDC ID Token
urn:ietf:params:oauth:token-type:jwt 泛 JWT
urn:ietf:params:oauth:token-type:saml2 SAML 2.0 assertion

Agent 场景典型组合:

2.3 请求示例(格式来自 RFC 8693 §2.1,非厂商响应)

POST /token HTTP/1.1
Host: as.example.com
Content-Type: application/x-www-form-urlencoded
Authorization: Basic <client_credentials>

grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Atoken-exchange
&subject_token=<user_access_token>
&subject_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token
&actor_token=<agent_access_token>
&actor_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token
&scope=read%3Amail
&resource=https%3A%2F%2Fapi.example.com%2Fmail
&requested_token_type=urn%3Aietf%3Aparams%3Aoauth%3Atoken-type%3Aaccess_token

AS 验证:subject token 有效、actor token 有效、client 被授权执行 exchange、请求的 scope ⊆ subject 的 scope、resource/audience 在允许列表内。

2.4 响应结构(RFC 8693 §2.2)

成功响应:

{
  "access_token": "eyJhbG...",
  "issued_token_type": "urn:ietf:params:oauth:token-type:access_token",
  "token_type": "Bearer",
  "expires_in": 3600,
  "scope": "read:mail"
}

access_token 若为 JWT,载荷结构见 §2.5。以上字段名与语义来自 RFC 8693,非虚构 IdP 响应——各 AS 可能在 JWT 内增加私有 claim,部署时必须以 IdP 文档为准。

2.5 JWT 中的 act claim(RFC 8693 §4.1)

换发后的 access token(JWT 形态)可携带 actor 声明:

{
  "iss": "https://idp.example.com",
  "sub": "user-248289761001",
  "aud": "https://api.example.com",
  "scope": "read:mail",
  "exp": 1718400000,
  "iat": 1718396400,
  "act": {
    "sub": "agent-checkout-bot",
    "iss": "https://idp.example.com"
  }
}

语义:

RS 验证后,审计日志应同时记录 subact.sub(及 client_id 若存在)。

2.6 may_act claim(RFC 8693 §4.4)

act 相对,may_act 出现在 subject token 上,声明「谁被允许代理此 subject」:

{
  "sub": "user-248289761001",
  "may_act": {
    "sub": "agent-checkout-bot",
    "iss": "https://idp.example.com"
  }
}

AS 在 Token Exchange 时检查:请求的 actor_token 主体是否匹配 may_act。用户 consent UI 可写入 may_act 约束——仅允许特定 Agent client 代理。

2.7 Impersonation vs Delegation(RFC 8693 §1.2)

模式 语义 Token 表现 Agent 场景
Impersonation Actor 成为 subject 输出 token 的 sub = 原 subject,可能无 act 不推荐——审计丢失 Agent 信息
Delegation Actor 代表 subject 输出 token 的 sub = subject,act = actor 推荐

工程判断:若 RS 日志无法区分 Agent 与用户本人,选 Delegation + act


三、Token Exchange 时序

3.1 标准委托流

sequenceDiagram
  participant User
  participant Agent as Agent Runtime
  participant GW as Agent Gateway
  participant IdP as Authorization Server
  participant API as Resource Server

  User->>Agent: 发起任务 + 已完成 OAuth consent
  Agent->>GW: 请求 delegated token scope=read:mail
  GW->>IdP: 用 SA 换 agent_access_token
  IdP->>GW: agent_access_token
  GW->>IdP: Token Exchange subject=user_token actor=agent_token
  IdP->>GW: delegated_access_token with act claim
  GW->>Agent: 短期 delegated token
  Agent->>API: Bearer delegated_access_token
  API->>API: JWKS 验签 + 检查 act + 写审计

Gateway 集中持有 user refresh token,Agent 只拿分钟级 delegated token——对齐 API Gateway 认证 的 BFF 模式。

3.2 用户首次授权与后续 Exchange

sequenceDiagram
  participant User
  participant Browser
  participant IdP
  participant GW as Agent Gateway

  User->>Browser: 启用 Agent 功能
  Browser->>IdP: OIDC authorize scope=read:mail + offline_access
  IdP->>Browser: authorization code
  Browser->>IdP: code + PKCE verifier
  IdP->>GW: access_token + refresh_token
  Note over GW: refresh_token 仅存 Gateway 加密存储

  loop 每次 Agent 任务
    GW->>IdP: refresh → user_access_token
    GW->>IdP: Token Exchange
    IdP->>GW: delegated token
  end

offline_access scope 使 Gateway 能在用户不在线时代为 refresh——用户必须在 consent 时明确授权 Agent 持续访问,且 consent 记录可审计。


四、与 OIDC / Service Account 的集成

4.1 OIDC ID Token 作为 subject_token?

部分 AS 接受 ID Token 作为 subject_token。ID Token 含 subaud(client_id),但通常不含 API scope。Exchange 时 AS 应查用户 consent 记录或 session 以确定可发 scope。

工程建议:优先用 access token 作 subject_token——scope 显式、与 RS 授权一致。

4.2 Service Account 作为 actor_token

Agent 运行在 K8s 时:

1. Pod 用 K8s SA JWT 或 SPIFFE SVID 向 IdP 换 agent_access_token
2. agent_access_token 的 sub = spiffe://cluster/ns/sa/checkout-agent
3. Token Exchange 时 actor_token = 该 agent_access_token
4. 输出 delegated token 的 act.sub = 同上 SPIFFE ID

Workload Identity 证明「进程身份」;Token Exchange 叠加「用户委托」——二者不可互相替代。

4.3 JWT 验证清单(RS 侧)

RS 收到 delegated JWT 时,除 JWKS 标准检查 外:

检查项 说明
act 存在且结构合法 对象含 sub;可选 iss 与 token iss 一致
act.sub 在允许 Agent 列表 或通过 策略引擎 动态判断
scope 覆盖本次操作 不足则 403
aud / resource 匹配本 RS 防 token 重放至其他 API
exp - iat ≤ 策略上限 Agent token 建议 ≤ 15 分钟

五、OBO 与 RFC 8693 的对照

Microsoft Entra ID、Azure AD 的 On-Behalf-Of (OBO) 流语义接近 Token Exchange,但非严格 RFC 8693

维度 RFC 8693 Entra OBO
Grant type token-exchange URN 自定义 urn:ietf:params:oauth:grant-type:jwt-bearer 扩展
Actor claim act 部分场景用 idtypappid 组合
文档 RFC 8693 §4.1 Microsoft identity platform docs

跨云集成:抽象 Agent Gateway,对内统一 delegated token 格式,对外适配各 IdP OBO/Exchange 实现。勿假设 payload 字段名跨云一致。

Keycloak(截至 2026-06 官方文档):支持 Token Exchange,需配置 token-exchange 权限与 Fine-Grain Admin Permissions。actor client 需被授权对 target client 执行 exchange。


六、Scope 缩小与 Resource Indicator

RFC 8693 §2.1:scope 参数请求的 scope 不得超过 subject token 已有 scope。Agent 任务级授权示例:

用户 consent scope Agent 任务 Exchange 请求 scope
read:mail send:mail read:calendar 仅读邮件 read:mail
read:orders write:orders 只读查询 read:orders

RFC 8707 Resource Indicators:resource 参数绑定 token 的 aud,防止 delegated token 被用于其他 API。Agent 调邮件 API 时 resource=https://mail-api.example.com


七、威胁模型

威胁 Gen2 脆弱性 Gen4 缓解
Agent 进程被攻破 attacker 持 user refresh token 仅短期 delegated token;无 refresh
用户 revoke 会话 Agent 仍可 refresh Gateway refresh 失败 → Exchange 停止
Token 重放至其他 RS aud resource + 窄 aud
权限提升 Agent 拿全 user scope Exchange 时显式 scope= 缩小
审计抵赖 日志无 Agent id act.sub 强制记录

零信任持续验证 联动:CAEP session-revoked 事件到达后,Gateway 停止 Exchange 并通知 Agent 终止(见 第 08 篇)。


八、工程坑点清单

  1. 把用户 refresh token 塞给 Agent 进程——见 §1.2。
  2. scope 不缩小——Token Exchange 应显式传 scope=
  3. act 仍称委托——仅转发 user bearer token 不是 Gen4。
  4. actor 与 subject 同一 client_id——部分 IdP 要求分离 OAuth client,否则 audit log 混淆。
  5. 忽略 may_act 约束——用户仅授权特定 Agent 时 AS 须校验。
  6. delegated token TTL 过长——建议 ≤ 15 分钟;长任务用 refresh Exchange 续期而非长 TTL。
  7. RS 不解析 act——合规审计失败。
  8. 跨 region 缓存 JWKS 过期——Agent 高峰时验签失败;需 JWKS 刷新策略。

九、迁移路径:Gen2 → Gen4

flowchart TD
  S["现状: Agent 持 user refresh token"] --> A["Step1: 引入 Agent Gateway"]
  A --> B["Step2: refresh token 迁入 Gateway 加密存储"]
  B --> C["Step3: Agent 改拿 Gateway 签发的 opaque/ JWT session token"]
  C --> D["Step4: IdP 开启 Token Exchange"]
  D --> E["Step5: Gateway 用 Exchange 换 delegated token 转发 API"]
  E --> F["Step6: RS 启用 act 审计 + 策略引擎"]
阶段 用户可见变化 回滚
Gateway 引入 双写 token 路径
refresh 迁移 可能需 re-consent Gateway 仍可读旧存储
Exchange 启用 降级为 Gateway 直接转发 user access token(临时)

身份系统迁移 相同原则:分阶段、可观测、可回滚。


十、决策矩阵:选哪一代?

场景 推荐代际 理由
只读公开 API Gen1 可接受 无用户上下文
原型 / 内部工具 Gen2 + Gateway 快速,但尽快迁 Gen4
批处理 ETL 无用户 Gen3 SA 无委托需求
用户委托的个人 Agent Gen4 归因 + 撤销 + scope 缩小
企业 Copilot 读邮件 Gen4 + 细粒度 scope 资源级 consent
MCP Host 调 remote Server Gen4 + per-server token 第 06 篇

十一、与后续篇章的衔接


十二、边界

十三、RFC 8693 错误响应语义

Token Exchange 失败时 AS 返回 OAuth 2.0 标准 error(RFC 8693 §2.2.2,A 级):

error 含义 Agent Gateway 动作
invalid_request 缺参数或格式错 修配置,勿重试
invalid_target resource/audience 不被支持 换 resource 或联系 IdP
invalid_client client 认证失败 检查 SA 凭据
invalid_grant subject/actor token 无效或过期 refresh user token 后重试
unauthorized_client client 无 exchange 权限 IAM 工单
access_denied AS 拒绝(policy) 通知用户 scope 不足
unsupported_token_type token 类型不匹配 检查 URN
invalid_scope 请求 scope 超限 缩小 scope

Gateway 应对 invalid_grant 区分:user session 失效(通知用户 re-auth)vs agent token 失效(轮换 SA)。


十四、嵌套委托与 act

RFC 8693 允许多层 act——编排 Agent 再调 worker Agent 时,JWT 可能含嵌套 act。审计须 flatten 整条链;策略可限制链深度 ≤ 2。


十五、Token Exchange 与 Client Credentials 的区别

Grant 用途 含 user sub
Client Credentials 服务自身身份
Token Exchange + subject + actor 用户委托

Agent 读用户数据必须后者。


十六、Consent 与 SCIM 删除

用户账号删除时 Delegation Store cascade revoke——见 SCIM 供给


十七、总结表:Gen1–Gen4

维度 Gen1 Gen2 Gen3 Gen4
用户归因
Agent 归因 Key id SA act
撤销
合规

二十六.1 工程深化:Exchange 幂等性

Agent Gateway 在处理 RFC 8693 Token Exchange 时,Exchange 幂等性 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 Exchange 幂等性 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 Exchange 幂等性 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"Exchange 幂等性 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 Exchange 幂等性 相关 incident 无法归因。

二十六.2 工程深化:client authentication

Agent Gateway 在处理 RFC 8693 Token Exchange 时,client authentication 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 client authentication 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 client authentication 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"client authentication 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 client authentication 相关 incident 无法归因。

二十六.3 工程深化:audience 验证

Agent Gateway 在处理 RFC 8693 Token Exchange 时,audience 验证 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 audience 验证 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 audience 验证 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"audience 验证 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 audience 验证 相关 incident 无法归因。

二十六.4 工程深化:权限继承

Agent Gateway 在处理 RFC 8693 Token Exchange 时,权限继承 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 权限继承 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 权限继承 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"权限继承 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 权限继承 相关 incident 无法归因。

二十六.5 工程深化:token 缓存

Agent Gateway 在处理 RFC 8693 Token Exchange 时,token 缓存 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 token 缓存 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 token 缓存 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"token 缓存 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 token 缓存 相关 incident 无法归因。

二十六.6 工程深化:clock skew

Agent Gateway 在处理 RFC 8693 Token Exchange 时,clock skew 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 clock skew 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 clock skew 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"clock skew 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 clock skew 相关 incident 无法归因。

二十六.7 工程深化:multi-tenant

Agent Gateway 在处理 RFC 8693 Token Exchange 时,multi-tenant 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 multi-tenant 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 multi-tenant 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"multi-tenant 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 multi-tenant 相关 incident 无法归因。

二十六.8 工程深化:federation

Agent Gateway 在处理 RFC 8693 Token Exchange 时,federation 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 federation 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 federation 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"federation 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 federation 相关 incident 无法归因。

二十六.9 工程深化:logout 语义

Agent Gateway 在处理 RFC 8693 Token Exchange 时,logout 语义 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 logout 语义 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 logout 语义 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"logout 语义 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 logout 语义 相关 incident 无法归因。

二十六.10 工程深化:device binding

Agent Gateway 在处理 RFC 8693 Token Exchange 时,device binding 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 device binding 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 device binding 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"device binding 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 device binding 相关 incident 无法归因。

二十六.11 工程深化:risk signal

Agent Gateway 在处理 RFC 8693 Token Exchange 时,risk signal 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 risk signal 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 risk signal 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"risk signal 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 risk signal 相关 incident 无法归因。

二十六.12 工程深化:compliance 证据

Agent Gateway 在处理 RFC 8693 Token Exchange 时,compliance 证据 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 compliance 证据 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 compliance 证据 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"compliance 证据 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 compliance 证据 相关 incident 无法归因。

二十六.13 工程深化:load test

Agent Gateway 在处理 RFC 8693 Token Exchange 时,load test 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 load test 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 load test 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"load test 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 load test 相关 incident 无法归因。

二十六.14 工程深化:chaos 测试

Agent Gateway 在处理 RFC 8693 Token Exchange 时,chaos 测试 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 chaos 测试 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 chaos 测试 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"chaos 测试 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 chaos 测试 相关 incident 无法归因。

二十六.15 工程深化:文档化

Agent Gateway 在处理 RFC 8693 Token Exchange 时,文档化 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 文档化 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 文档化 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"文档化 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 文档化 相关 incident 无法归因。

二十六.16 工程深化:on-call

Agent Gateway 在处理 RFC 8693 Token Exchange 时,on-call 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 on-call 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 on-call 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"on-call 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 on-call 相关 incident 无法归因。

二十六.17 工程深化:Exchange 幂等性

Agent Gateway 在处理 RFC 8693 Token Exchange 时,Exchange 幂等性 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 Exchange 幂等性 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 Exchange 幂等性 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"Exchange 幂等性 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 Exchange 幂等性 相关 incident 无法归因。

二十六.18 工程深化:client authentication

Agent Gateway 在处理 RFC 8693 Token Exchange 时,client authentication 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 client authentication 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 client authentication 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"client authentication 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 client authentication 相关 incident 无法归因。

二十六.19 工程深化:audience 验证

Agent Gateway 在处理 RFC 8693 Token Exchange 时,audience 验证 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 audience 验证 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 audience 验证 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"audience 验证 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 audience 验证 相关 incident 无法归因。

二十六.20 工程深化:权限继承

Agent Gateway 在处理 RFC 8693 Token Exchange 时,权限继承 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 权限继承 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 权限继承 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"权限继承 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 权限继承 相关 incident 无法归因。

二十六.21 工程深化:token 缓存

Agent Gateway 在处理 RFC 8693 Token Exchange 时,token 缓存 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 token 缓存 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 token 缓存 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"token 缓存 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 token 缓存 相关 incident 无法归因。

二十六.22 工程深化:clock skew

Agent Gateway 在处理 RFC 8693 Token Exchange 时,clock skew 是常见评审项。设计检查:

检查 通过标准
文档 runbook 含 clock skew 故障路径
监控 metric 覆盖 Exchange 失败率
测试 CI 含 clock skew 回归 case
IAM 联动 JWT 验证 策略一致
flowchart TD
  REQ[Exchange 请求] --> CHK{"clock skew 检查"}
  CHK -->|pass| OK[签发 delegated token]
  CHK -->|fail| ERR[OAuth error]

委托 token 的 act claim 必须在 RS 审计中可解析——否则 clock skew 相关 incident 无法归因。

附录 A、Agent 身份谱系 场景演练

A.1 邮件摘要 Agent

步骤 动作
1 用户 consent read:mail
2 Exchange scope=read:mail:inbox
3 OPA 限 folder
4 audit 含 act
flowchart LR
  S1["用户 consent read:mail"] --> S2["Exchange scope=read:mail:inbox"]
  S2 --> S3["OPA 限 folder"]
  S3 --> S4["audit 含 act"]

A.2 SQL 分析 Agent

步骤 动作
1 read:warehouse
2 只读 DB role
3 Rego deny DDL
4 HITL 导出 CSV >10k rows
flowchart LR
  S1["read:warehouse"] --> S2["只读 DB role"]
  S2 --> S3["Rego deny DDL"]
  S3 --> S4["HITL 导出 CSV >10k rows"]

A.3 MCP Git Agent

步骤 动作
1 per-server OAuth
2 stdio pin version
3 tool allowlist
4 supply chain SBOM
flowchart LR
  S1["per-server OAuth"] --> S2["stdio pin version"]
  S2 --> S3["tool allowlist"]
  S3 --> S4["supply chain SBOM"]

A.4 跨 API 编排

步骤 动作
1 多 resource Exchange
2 每 API 独立 token
3 Gateway 聚合
4 trace 串联
flowchart LR
  S1["多 resource Exchange"] --> S2["每 API 独立 token"]
  S2 --> S3["Gateway 聚合"]
  S3 --> S4["trace 串联"]

A.5 offboarding

步骤 动作
1 SCIM deactivate
2 CAEP or TTL
3 cache flush
4 audit retention
flowchart LR
  S1["SCIM deactivate"] --> S2["CAEP or TTL"]
  S2 --> S3["cache flush"]
  S3 --> S4["audit retention"]

A.6 供应链攻击响应

步骤 动作
1 disconnect MCP Server
2 rotate per-server token
3 SBOM diff
4 post-incident audit
flowchart LR
  S1["disconnect MCP Server"] --> S2["rotate per-server token"]
  S2 --> S3["SBOM diff"]
  S3 --> S4["post-incident audit"]

A.7 HITL 超时

步骤 动作
1 pending transfer
2 7200s expire
3 Agent Cancelled
4 audit expired
flowchart LR
  S1["pending transfer"] --> S2["7200s expire"]
  S2 --> S3["Agent Cancelled"]
  S3 --> S4["audit expired"]

A.8 跨云 OBO

步骤 动作
1 Entra user token
2 Gateway normalize act
3 RS 统一 audit schema
4 policy 同构
flowchart LR
  S1["Entra user token"] --> S2["Gateway normalize act"]
  S2 --> S3["RS 统一 audit schema"]
  S3 --> S4["policy 同构"]

附录 B、Agent 身份谱系 常见问题

Q:能否省略 Agent Gateway?
A:仅当 Agent 永不持 user refresh 且 RS 支持 Token Exchange 直联——多数企业仍要 Gateway 聚 policy、HITL、audit。

Q:MCP 是否替代 OAuth?
A:否。MCP 管 tool 协议;OAuth 管身份。

Q:CAEP 未支持怎么办?
A:短 TTL(≤15min)为基线;heartbeat 补 Gateway 层 revoke。

Q:如何证明 Agent 未越权?
A:deny 日志 + policy_version + 定期 access review(IGA)。

Q:Gen2 到 Gen4 最小步骤?
A:Gateway 托管 refresh → 启用 Exchange → RS 解析 act → 下线 Agent 侧 refresh。



上一篇系列索引

下一篇细粒度 Scope 与 UMA


参考资料

  1. IETF RFC 8693, OAuth 2.0 Token Exchange, Section 2–4, 2018
  2. IETF RFC 8707, Resource Indicators for OAuth 2.0, 2020
  3. IETF RFC 7519, JSON Web Token (JWT)
  4. OpenID Connect Core 1.0, Section 2 ID Token
  5. Keycloak Documentation, Token Exchange(阅读日期 2026-06)
  6. Microsoft Learn, Microsoft identity platform and the OAuth 2.0 On-Behalf-Of flow(B 级,语义对照用)

同主题继续阅读

把当前热点继续串成多页阅读,而不是停在单篇消费。

2026-06-18 · architecture / security

【Agent 身份与安全】AI Agent 的身份、委托与审计

IAM 系列(人)与零信任系列(边界)的自然延伸:当 LLM Agent 代表用户调用 API、执行 SQL、读写邮件时,传统 OAuth 模型如何扩展?拆解 Token Exchange、MCP 安全模型、工具级授权、持续验证与审计归因。

2026-06-18 · architecture / security

【Agent 身份与安全】MCP 架构与安全基线

Model Context Protocol 的 Host/Client/Server 三角、stdio 与 Streamable HTTP Transport 安全差异、OAuth 2.1 for MCP 草案边界,以及多 Server secret 隔离与 tool 攻击面。

2026-06-13 · architecture / security

【身份与访问控制工程】IAM 全景:为什么这是高价值赛道

从 2020 年 SolarWinds 到 2024 年 Okta 支持系统泄露,身份基础设施的安全失败反复证明一件事:IAM 不是 IT 支撑系统,而是安全架构的承重墙。本文建立现代 IAM 的全景地图——从认证协议、令牌体系、权限模型到身份治理与平台选型,给出 5 个贯穿全系列的核心问题。


By .