本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
RevokeGrant 搭配 AWS SDK 或 CLI 使用
下列程式碼範例示範如何使用 RevokeGrant。
動作範例是大型程式的程式碼摘錄,必須在內容中執行。您可以在下列程式碼範例的內容中看到此動作:
- CLI
- 
            - AWS CLI
- 
             
                    撤銷客戶主金鑰的授予 下列 revoke-grant範例會從 KMS 金鑰刪除授予。下列範例命令會指定grant-id和key-id參數。key-id參數的值可以是 KMS 金鑰的金鑰 ID 或金鑰 ARN。aws kms revoke-grant \ --grant-id1234a2345b8a4e350500d432bccf8ecd6506710e1391880c4f7f7140160c9af3\ --key-id1234abcd-12ab-34cd-56ef-1234567890ab此命令不會產生輸出。若要確認授予已撤銷,請使用 list-grants命令。如需詳細資訊,請參閱 AWS Key Management Service 開發人員指南中的淘汰和撤銷授予。 - 
                    如需 API 詳細資訊,請參閱《 AWS CLI 命令參考》中的 RevokeGrant 。 
 
- 
                    
 
- Java
- 
            - SDK for Java 2.x
- 
注意GitHub 上提供更多範例。尋找完整範例,並了解如何在 AWS 程式碼範例儲存庫 中設定和執行。 /** * Revokes a grant for the specified AWS KMS key asynchronously. * * @param keyId The ID or key ARN of the AWS KMS key. * @param grantId The identifier of the grant to be revoked. * @return A {@link CompletableFuture} representing the asynchronous operation of revoking the grant. * The {@link CompletableFuture} will complete with a {@link RevokeGrantResponse} object * if the operation is successful, or with a {@code null} value if an error occurs. */ public CompletableFuture<RevokeGrantResponse> revokeKeyGrantAsync(String keyId, String grantId) { RevokeGrantRequest grantRequest = RevokeGrantRequest.builder() .keyId(keyId) .grantId(grantId) .build(); CompletableFuture<RevokeGrantResponse> responseFuture = getAsyncClient().revokeGrant(grantRequest); responseFuture.whenComplete((response, exception) -> { if (exception == null) { logger.info("Grant ID: [" + grantId + "] was successfully revoked!"); } else { if (exception instanceof KmsException kmsEx) { if (kmsEx.getMessage().contains("Grant does not exist")) { logger.info("The grant ID '" + grantId + "' does not exist. Moving on..."); } else { throw new RuntimeException("KMS error occurred: " + kmsEx.getMessage(), kmsEx); } } else { throw new RuntimeException("An unexpected error occurred: " + exception.getMessage(), exception); } } }); return responseFuture; }- 
                    如需 API 詳細資訊,請參閱AWS SDK for Java 2.x 《 API 參考》中的 RevokeGrant。 
 
- 
                    
 
- PHP
- 
            - SDK for PHP
- 
注意GitHub 上提供更多範例。尋找完整範例,並了解如何在 AWS 程式碼範例儲存庫 中設定和執行。 /*** * @param string $grantId * @param string $keyId * @return void */ public function revokeGrant(string $grantId, string $keyId) { try{ $this->client->revokeGrant([ 'GrantId' => $grantId, 'KeyId' => $keyId, ]); }catch(KmsException $caught){ echo "There was a problem with revoking the grant: {$caught->getAwsErrorMessage()}.\n"; throw $caught; } }- 
                    如需 API 詳細資訊,請參閱適用於 PHP 的 AWS SDK 《 API 參考》中的 RevokeGrant。 
 
- 
                    
 
- Python
- 
            - SDK for Python (Boto3)
- 
注意GitHub 上提供更多範例。尋找完整範例,並了解如何在 AWS 程式碼範例儲存庫 中設定和執行。 class GrantManager: def __init__(self, kms_client): self.kms_client = kms_client @classmethod def from_client(cls) -> "GrantManager": """ Creates a GrantManager instance with a default KMS client. :return: An instance of GrantManager initialized with the default KMS client. """ kms_client = boto3.client("kms") return cls(kms_client) def revoke_grant(self, key_id: str, grant_id: str) -> None: """ Revokes a grant so that it can no longer be used. :param key_id: The ARN or ID of the key associated with the grant. :param grant_id: The ID of the grant to revoke. """ try: self.kms_client.revoke_grant(KeyId=key_id, GrantId=grant_id) except ClientError as err: logger.error( "Couldn't revoke grant %s. Here's why: %s", grant_id, err.response["Error"]["Message"], ) raise- 
                    如需 API 詳細資訊,請參閱《適用於 AWS Python (Boto3) 的 SDK API 參考》中的 RevokeGrant。 
 
- 
                    
 
如需 AWS SDK 開發人員指南和程式碼範例的完整清單,請參閱 搭配 AWS SDK 使用此服務。此主題也包含有關入門的資訊和舊版 SDK 的詳細資訊。