本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
GetKeyPolicy
搭配 AWS SDK或 使用 CLI
下列程式碼範例示範如何使用 GetKeyPolicy
。
動作範例是大型程式的程式碼摘錄,必須在內容中執行。您可以在下列程式碼範例的內容中看到此動作:
- CLI
-
- AWS CLI
-
將金鑰政策從一個KMS金鑰複製到另一個KMS金鑰
下列
get-key-policy
範例會從一個KMS金鑰取得金鑰政策,並將其儲存在文字檔案中。然後,它會使用文字檔案作為政策輸入來取代不同KMS金鑰的政策。由於 的
--policy
參數put-key-policy
需要字串,因此您必須使用--output text
選項,將輸出傳回為文字字串,而非 JSON。aws kms get-key-policy \ --policy-name
default
\ --key-id1234abcd-12ab-34cd-56ef-1234567890ab
\ --queryPolicy
\ --outputtext
>
policy.txt
aws
kms
put-key-policy
\ --policy-namedefault
\ --key-id0987dcba-09fe-87dc-65ba-ab0987654321
\ --policyfile://policy.txt
此命令不會產生輸出。
如需詳細資訊,請參閱 參考 PutKeyPolicy中的 。 AWS KMS API
-
如需API詳細資訊,請參閱 命令參考 GetKeyPolicy
中的 。 AWS CLI
-
- 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 get_policy(self, key_id: str) -> dict[str, str]: """ Gets the policy of a key. :param key_id: The ARN or ID of the key to query. :return: The key policy as a dict. """ if key_id != "": try: response = self.kms_client.get_key_policy( KeyId=key_id, ) policy = json.loads(response["Policy"]) except ClientError as err: logger.error( "Couldn't get policy for key %s. Here's why: %s", key_id, err.response["Error"]["Message"], ) raise else: pprint(policy) return policy else: print("Skipping get policy demo.")
-
如需API詳細資訊,請參閱 GetKeyPolicy 中的 AWS SDK for Python (Boto3) API參考 。
-
如需開發人員指南和程式碼範例的完整清單 AWS SDK,請參閱 將此服務與 搭配使用 AWS SDK。本主題也包含有關入門的資訊,以及先前SDK版本的詳細資訊。
GenerateRandom
ListAliases