本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
AWS Security Token Service 的操作、资源和条件键
AWS 安全令牌服务(服务前缀:sts
)提供以下特定于服务的资源、操作和条件上下文密钥,供在 IAM 权限策略中使用。
参考:
AWS Security Token Service 定义的操作
您可以在 IAM 策略语句的 Action
元素中指定以下操作。可以使用策略授予在 AWS中执行操作的权限。您在策略中使用一项操作时,通常使用相同的名称允许或拒绝对 API 操作或 CLI 命令的访问。但在某些情况下,单一动作可控制对多项操作的访问。还有某些操作需要多种不同的动作。
操作表的资源类型列指示每项操作是否支持资源级权限。如果该列没有任何值,您必须在策略语句的 Resource
元素中指定策略应用的所有资源(“*”)。通过在 IAM policy 中使用条件来筛选访问权限,以控制是否可以在资源或请求中使用特定标签键。如果操作具有一个或多个必需资源,则调用方必须具有使用这些资源来使用该操作的权限。必需资源在表中以星号 (*) 表示。如果您在 IAM policy 中使用 Resource
元素限制资源访问权限,则必须为每种必需的资源类型添加 ARN 或模式。某些操作支持多种资源类型。如果资源类型是可选的(未指示为必需),则可以选择使用一种可选资源类型。
操作表的条件键列包括可以在策略语句的 Condition
元素中指定的键。有关与服务资源关联的条件键的更多信息,请参阅资源类型表的条件键列。
注意
资源条件键在资源类型表中列出。您可以在操作表的资源类型(* 为必需)列中找到应用于某项操作的资源类型的链接。资源类型表中的资源类型包括条件密钥列,这是应用于操作表中操作的资源条件键。
有关下表中各列的详细信息,请参阅操作表。
操作 | 描述 | 访问级别 | 资源类型(* 为必需) | 条件键 | 相关操作 |
---|---|---|---|---|---|
AssumeRole | 授予获取一组临时安全证书的权限,您可以使用这些证书来访问通常可能无法访问的 AWS 资源 | 写入 | |||
cognito-identity.amazonaws.com:amr cognito-identity.amazonaws.com:aud |
|||||
AssumeRoleWithSAML | 授予权限以获取为已通过 SAML 身份验证响应进行身份验证的用户获取一组临时安全凭证 | 写入 | |||
saml:eduorgidentityauthnpolicyuri saml:edupersonprimaryaffiliation saml:edupersonprimaryorgunitdn |
|||||
AssumeRoleWithWebIdentity | 授予权限为已在移动或 Web 应用程序中使用 Web 身份提供商进行身份验证的用户获取一组临时安全凭证 | 写入 | |||
cognito-identity.amazonaws.com:amr cognito-identity.amazonaws.com:aud |
|||||
DecodeAuthorizationMessage | 授予从响应请求时返回的编码消息中解码有关请求授权状态的其他信息的权限 AWS | 写入 | |||
GetAccessKeyInfo | 授予权限以获取有关作为参数传递给请求的访问密钥 ID 的详细信息 | 读取 | |||
GetCallerIdentity | 授予权限以获取有关其凭证用于调用 API 的 IAM 身份的详细信息 | 读取 | |||
GetFederationToken | 授予权限以为联合身份用户获取一组临时安全凭证(由访问密钥 ID、秘密访问密钥和安全令牌组成) | 读取 | |||
GetServiceBearerToken [仅权限] | 为 AWS 根用户、IAM 角色或 IAM 用户授予获取 STS 持有者令牌的权限 | 读取 | |||
GetSessionToken | 授予权限以获取 AWS 账户 或 IAM 用户的一组临时安全证书(包括访问密钥 ID、私有访问密钥和安全令牌) | 读取 | |||
SetContext [仅权限] | 授予为 STS 会话设置上下文键的权限 | 写入 | |||
SetSourceIdentity [仅权限] | 授予在 STS 会话上设置源身份的权限 | Write | |||
TagSession [仅权限] | 授予权限以将标签添加至 STS 会话 | Tagging | |||
AWS Security Token Service 定义的资源类型
以下资源类型是由该服务定义的,可以在 IAM 权限策略语句的 Resource
元素中使用这些资源类型。操作表中的每个操作指定了可以使用该操作指定的资源类型。您也可以在策略中包含条件键,从而定义资源类型。这些键显示在表的最后一列。有关下表中各列的详细信息,请参阅资源类型表。
资源类型 | ARN | 条件键 |
---|---|---|
role |
arn:${Partition}:iam::${Account}:role/${RoleNameWithPath}
|
|
user |
arn:${Partition}:iam::${Account}:user/${UserNameWithPath}
|
|
self-session |
arn:${Partition}:sts::${Account}:self
|
AWS Security Token Service 的条件键
AWS 安全令牌服务定义了以下条件密钥,这些密钥可用于 IAM 策略的Condition
元素。您可以使用这些键进一步细化应用策略语句的条件。有关下表中各列的详细信息,请参阅条件键表。
要查看适用于所有服务的全局条件键,请参阅可用的全局条件键。
条件键 | 描述 | 类型 |
---|---|---|
accounts.google.com:aud | 按 Google 应用程序 ID 筛选访问权限 | String |
accounts.google.com:oaud | 按 Google 受众筛选访问权限 | String |
accounts.google.com:sub | 按声明的主体(Google 用户 ID)筛选访问权限 | String |
aws:RequestTag/${TagKey} | 按请求中传递的标签筛选访问权限 | 字符串 |
aws:ResourceTag/${TagKey} | 按与资源关联的标签筛选访问权限 | 字符串 |
aws:TagKeys | 按请求中传递的标签键筛选访问权限 | ArrayOfString |
cognito-identity.amazonaws.com:amr | 按 Amazon Cognito 的登录信息筛选访问权限 | String |
cognito-identity.amazonaws.com:aud | 按 Amazon Cognito 身份池 ID 筛选访问权限 | String |
cognito-identity.amazonaws.com:sub | 按声明的主体(Amazon Cognito 用户 ID)筛选访问权限 | String |
graph.facebook.com:app_id | 按 Facebook 应用程序 ID 筛选访问权限 | String |
graph.facebook.com:id | 按 Facebook 用户 ID 筛选访问权限 | String |
iam:ResourceTag/${TagKey} | 按附加到所要代入角色的标签筛选访问权限 | String |
saml:aud | 按向其提供 SAML 断言的终端节点 URL 筛选访问权限 | String |
saml:cn | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:commonName | 按 commonName 属性筛选访问权限 | String |
saml:doc | 按用于担任角色的主体筛选访问权限 | String |
saml:eduorghomepageuri | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:eduorgidentityauthnpolicyuri | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:eduorglegalname | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:eduorgsuperioruri | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:eduorgwhitepagesuri | 按 eduOrg 属性筛选访问权限 | ArrayOfString |
saml:edupersonaffiliation | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersonassurance | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersonentitlement | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersonnickname | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersonorgdn | 按 eduPerson 属性筛选访问权限 | String |
saml:edupersonorgunitdn | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersonprimaryaffiliation | 按 eduPerson 属性筛选访问权限 | String |
saml:edupersonprimaryorgunitdn | 按 eduPerson 属性筛选访问权限 | String |
saml:edupersonprincipalname | 按 eduPerson 属性筛选访问权限 | String |
saml:edupersonscopedaffiliation | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:edupersontargetedid | 按 eduPerson 属性筛选访问权限 | ArrayOfString |
saml:givenName | 按 givenName 属性筛选访问权限 | String |
saml:iss | 按发布者(由 URN 表示)筛选访问权限 | String |
saml:mail | 按邮件属性筛选访问权限 | String |
saml:name | 按名称属性筛选访问权限 | String |
saml:namequalifier | 按发布者、账户 ID 和友好名称的哈希值筛选访问权限 | String |
saml:organizationStatus | 按 organizationStatus 属性筛选访问权限 | String |
saml:primaryGroupSID | 按 primaryGroupSID 属性筛选访问权限 | String |
saml:sub | 按声明的主体(SAML 用户 ID)筛选访问权限 | String |
saml:sub_type | 按值持久性、瞬态或完整格式 URI 筛选访问权限 | String |
saml:surname | 按姓氏属性筛选访问权限 | String |
saml:uid | 按 uid 属性筛选访问权限 | String |
saml:x500UniqueIdentifier | 按 uid 属性筛选访问权限 | String |
sts:AWSServiceName | 按正在获取持有者令牌的服务筛选访问权限 | String |
sts:DurationSeconds | 按获取持有者令牌时的持续时间(以秒为单位)筛选访问权限 | String |
sts:ExternalId | 按您代入另一个账户中的角色时所需的唯一标识符筛选访问权限 | String |
sts:RequestContext/${ContextKey} | 按从可信上下文提供者检索的已签名上下文断言中嵌入的会话上下文键值对筛选访问权限 | String |
sts:RequestContextProviders | 按上下文提供者 ARN 筛选访问权限 | ArrayOfARN |
sts:RoleSessionName | 按您代入角色时所需的角色会话名称筛选访问权限 | String |
sts:SourceIdentity | 按照在请求中传递的源身份筛选访问权限 | String |
sts:TransitiveTagKeys | 按照在请求中传递的可传递标签键筛选访问权限 | ArrayOfString |
www.amazon.com:app_id | 按照“Login with Amazon”应用程序 ID 筛选访问权限 | String |
www.amazon.com:user_id | 按照“Login with Amazon”用户 ID 筛选访问权限 | String |