全部產品
Search
文件中心

:AssumeRoleWithOIDC - OIDC角色SSO時擷取扮演角色的臨時身份憑證

更新時間:Aug 08, 2025

進行OIDC角色SSO時,通過調用AssumeRoleWithOIDC介面,擷取扮演RAM角色的臨時身份憑證(STS Token)。

介面說明

前提條件

調試

您可以在OpenAPI Explorer中直接運行該介面,免去您計算簽名的困擾。運行成功後,OpenAPI Explorer可以自動產生SDK程式碼範例。

調試

授權資訊

當前API暫無授權資訊透出。

請求參數

名稱

類型

必填

描述

樣本值

OIDCProviderArn

string

OIDC 身份供應商的 ARN。

您可以通過 RAM 控制台或 API 查看 OIDC 身份供應商的 ARN。具體如下:

acs:ram::113511544585****:oidc-provider/TestOidcIdp

RoleArn

string

需要扮演的 RAM 角色 ARN。

您可以通過 RAM 控制台或 API 查看角色 ARN。具體如下:

acs:ram::113511544585****:role/testoidc

OIDCToken

string

由外部 IdP 簽發的 OIDC 令牌(OIDC Token)。

長度:4~20000 個字元。

說明

需要輸入原始 OIDC Token,無需 Base64 解碼。

eyJraWQiOiJKQzl3eHpyaHFKMGd0****

Policy

string

為 STS Token 額外添加的一個權限原則,進一步限制 STS Token 的許可權。具體如下:

  • 如果指定該權限原則,則 STS Token 最終的許可權取 RAM 角色權限原則與該權限原則的交集。

  • 如果不指定該權限原則,則 STS Token 最終的許可權就是 RAM 角色的許可權。

長度:1~2048 個字元。

{"Statement": [{"Action": ["*"],"Effect": "Allow","Resource": ["*"]}],"Version":"1"}

DurationSeconds

integer

Token 有效期間。單位:秒。

預設值:3600。最小值:900。最大值:MaxSessionDuration設定的時間。

關於設定角色最大會話時間MaxSessionDuration的具體操作,請參見 CreateRoleUpdateRole

3600

RoleSessionName

string

角色會話名稱。

該參數為使用者自訂參數。通常設定為調用該 API 的使用者身份,例如:使用者名稱。在Action Trail日誌中,即使是同一個 RAM 角色執行的操作,也可以根據不同的 RoleSessionName 來區分實際操作者,以實現使用者層級的訪問審計。

格式:包含英文字母、數字、半形句號(.)、at(@)、短劃線(-)和底線(_)。

長度:2~64 個字元。

TestOidcAssumedRoleSession

說明

由於 AssumeRoleWithOIDC 介面使用 OIDC Token 進行身份認證,可以匿名訪問,因此不需要提供公用請求參數中的SignatureSignatureMethodSignatureVersionAccessKeyId參數。關於公用請求參數的詳情,請參見公用請求參數

返回參數

名稱

類型

描述

樣本值

object

返回參數。

RequestId

string

請求 ID。

3D57EAD2-8723-1F26-B69C-F8707D8B565D

OIDCTokenInfo

object

解析的 OIDC Token 資訊。

Subject

string

OIDC 主體。

對應 OIDC Token 中的sub欄位值。

KryrkIdjylZb7agUgCEf****

Issuer

string

OIDC 頒發者 URL。

對應 OIDC Token 中的iss欄位值。

https://dev-xxxxxx.okta.com

ClientIds

string

OIDC 受眾。多個之間用半形逗號(,)分隔。

對應 OIDC Token 中的aud欄位值。

496271242565057****

ExpirationTime

string

OIDC Token 的到期時間。

2021-10-20T04:27:09Z

IssuanceTime

string

OIDC Token 的簽發時間。

2021-10-20T03:27:09Z

VerificationInfo

string

OIDC Token 的檢驗資訊。更多資訊,請參見管理 OIDC 身份供應商

Success

AssumedRoleUser

object

角色扮演臨時身份。

AssumedRoleId

string

臨時身份的 ID。

33157794895460****

Arn

string

臨時身份的 ARN。

acs:ram::113511544585****:role/testoidc/TestOidcAssumedRoleSession

Credentials

object

臨時訪問憑證(STS Token)。

SecurityToken

string

安全性權杖。

說明

安全性權杖的長度不固定,我們強烈建議您不要對安全性權杖的最大長度做任何限制。

CAIShwJ1q6Ft5B2yfSjIr5bSEsj4g7BihPWGWHz****

Expiration

string

Token 到期失效時間(UTC 時間)。

2021-10-20T04:27:09Z

AccessKeySecret

string

存取金鑰。

CVwjCkNzTMupZ8NbTCxCBRq3K16jtcWFTJAyBEv2****

AccessKeyId

string

存取金鑰 ID。

STS.NUgYrLnoC37mZZCNnAbez****

SourceIdentity

string

源身份資訊。

在扮演角色時,可以指定扮演者的源身份(SourceIdentity)作為會話的初始身份標識。 該源身份的值在持續扮演角色的鏈式會話中將一直存在,中途不可更改,可確保操作的可追溯性和安全性。

如果沒有設定源身份資訊,則該欄位不會返回。

Alice

樣本

正常返回樣本

JSON格式

{
  "RequestId": "3D57EAD2-8723-1F26-B69C-F8707D8B565D",
  "OIDCTokenInfo": {
    "Subject": "KryrkIdjylZb7agUgCEf****",
    "Issuer": "https://dev-xxxxxx.okta.com",
    "ClientIds": "496271242565057****",
    "ExpirationTime": "2021-10-20T04:27:09Z",
    "IssuanceTime": "2021-10-20T03:27:09Z",
    "VerificationInfo": "Success"
  },
  "AssumedRoleUser": {
    "AssumedRoleId": "33157794895460****",
    "Arn": "acs:ram::113511544585****:role/testoidc/TestOidcAssumedRoleSession"
  },
  "Credentials": {
    "SecurityToken": "CAIShwJ1q6Ft5B2yfSjIr5bSEsj4g7BihPWGWHz****",
    "Expiration": "2021-10-20T04:27:09Z",
    "AccessKeySecret": "CVwjCkNzTMupZ8NbTCxCBRq3K16jtcWFTJAyBEv2****",
    "AccessKeyId": "STS.NUgYrLnoC37mZZCNnAbez****"
  },
  "SourceIdentity": "Alice"
}

錯誤碼

訪問錯誤中心查看更多錯誤碼。

變更歷史

更多資訊,參考變更詳情