本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
ListKeyPolicies
搭配 AWS SDK或 使用 CLI
下列程式碼範例示範如何使用 ListKeyPolicies
。
- CLI
-
- AWS CLI
-
取得金鑰的KMS金鑰政策名稱
下列
list-key-policies
範例會取得範例帳戶和區域中客戶受管金鑰之金鑰政策的名稱。您可以使用此命令來尋找 AWS 受管金鑰和客戶受管金鑰的金鑰政策名稱。由於唯一有效的金鑰政策名稱是
default
,因此此命令沒有用。若要指定KMS金鑰,請使用
key-id
參數。此範例使用金鑰 ID 值,但您可以在此命令ARN中使用金鑰 ID 或金鑰。aws kms list-key-policies \ --key-id
1234abcd-12ab-34cd-56ef-1234567890ab
輸出:
{ "PolicyNames": [ "default" ] }
如需有關金鑰政策的詳細資訊 AWS KMS,請參閱 金鑰AWS 管理服務開發人員指南 中的在 中使用金鑰政策 AWS KMS。
-
如需API詳細資訊,請參閱 命令參考 ListKeyPolicies
中的 。 AWS CLI
-
- Java
-
- SDK 適用於 Java 2.x
-
注意
還有更多 。 GitHub尋找完整範例,並了解如何在 AWS 程式碼範例儲存庫
中設定和執行。 /** * Asynchronously retrieves the key policy for the specified key ID and policy name. * * @param keyId the ID of the AWS KMS key for which to retrieve the policy * @param policyName the name of the key policy to retrieve * @return a {@link CompletableFuture} that, when completed, contains the key policy as a {@link String} */ public CompletableFuture<String> getKeyPolicyAsync(String keyId, String policyName) { GetKeyPolicyRequest policyRequest = GetKeyPolicyRequest.builder() .keyId(keyId) .policyName(policyName) .build(); return getAsyncClient().getKeyPolicy(policyRequest) .thenApply(response -> { String policy = response.policy(); logger.info("The response is: " + policy); return policy; }) .exceptionally(ex -> { throw new RuntimeException("Failed to get key policy", ex); }); }
-
如需API詳細資訊,請參閱 參考 ListKeyPolicies中的 。 AWS SDK for Java 2.x API
-
- Python
-
- SDK for Python (Boto3)
-
注意
還有更多 。 GitHub尋找完整範例,並了解如何在 AWS 程式碼範例儲存庫
中設定和執行。 class KeyPolicy: def __init__(self, kms_client): self.kms_client = kms_client @classmethod def from_client(cls) -> "KeyPolicy": """ Creates a KeyPolicy instance with a default KMS client. :return: An instance of KeyPolicy initialized with the default KMS client. """ kms_client = boto3.client("kms") return cls(kms_client) def list_policies(self, key_id): """ Lists the names of the policies for a key. :param key_id: The ARN or ID of the key to query. """ try: policy_names = self.kms_client.list_key_policies(KeyId=key_id)[ "PolicyNames" ] except ClientError as err: logging.error( "Couldn't list your policies. Here's why: %s", err.response["Error"]["Message"], ) raise else: print(f"The policies for key {key_id} are:") pprint(policy_names)
-
如需API詳細資訊,請參閱 ListKeyPolicies 中的 AWS SDK for Python (Boto3) API參考 。
-
如需開發人員指南和程式碼範例的完整清單 AWS SDK,請參閱 將此服務與 搭配使用 AWS SDK。本主題也包含有關入門的資訊,以及先前SDK版本的詳細資訊。
ListGrants
ListKeys