Computer >> 컴퓨터 >  >> 프로그램 작성 >> Python

Boto3를 사용하여 AWS Secret Manager의 특정 위치에서 비밀 세부 정보를 가져오는 방법

<시간/>

문제 설명: boto3 사용 Python의 라이브러리를 사용하여 AWS Secret Manager의 특정 위치에서 비밀 세부 정보를 가져옵니다.

이 문제를 해결하기 위한 접근 방식/알고리즘

  • 1단계: boto3 가져오기 및 보토코어 예외를 처리하는 예외.

  • 2단계: secret_stored_location 필수 매개변수입니다.

  • 3단계: boto3 lib를 사용하여 AWS 세션 생성 . region_name을(를) 확인하십시오. 기본 프로필에 언급되어 있습니다. 언급되지 않은 경우 region_name을 명시적으로 전달합니다. 세션을 만드는 동안.

  • 4단계: secretmanager용 AWS 클라이언트 생성 .

  • 5단계: describe_secret 호출 secret_stored_location 전달 SecretId로 .

  • 6단계: 비밀의 메타데이터를 반환합니다.

  • 7단계: 비밀 정보를 가져오는 동안 문제가 발생한 경우 일반 예외를 처리합니다.

예시 코드

다음 코드를 사용하여 AWS secret Manager의 비밀 세부 정보를 얻으십시오 -

botocore.exceptions에서 boto3 가져오기 import ClientErrordef get_secret_details(secret_stored_location):session =boto3.session.Session() s3_client =session.client('secretmanager') try:response =s3_client.describe_secret(Secret_Response) as e:raise Exception("boto3 client error in get_secret_details:" + e.__str__()) 예외 as e:raise Exception("get_secret_details에서 예기치 않은 오류:" + e.__str__())a =get_secret_details('/secrets /aws')인쇄(a)

출력

{'ARN':'arn:aws:secretsmanager:us-east-1:****************:secret:/secrets/aws-wr1Aj6', '이름' :'/secrets/aws', 'LastChangedDate':datetime.datetime(2021, 4, 3, 17, 6, 57, 601000, tzinfo=tzlocal()), 'LastAccessedDate':datetime.datetime(2021, 4, 3) , 5, 30, tzinfo=tzlocal()), 'VersionIdsToStages':{'f5308bed-7c23-4d47-a32b-8f2a5f044e53':['AWSCURRENT'], 'fcdc1b5b-2a35-4d496:['AWSCURRENT'], 'fcdc1b5b-2a35-4d12 ']}, 'ResponseMetadata':{'RequestId':'b32fe48d**************ab', 'HTTPStatusCode':200, 'HTTPHeaders':{'date':'Sat, 2021년 4월 3일 09:40:48 GMT', 'content-type':'application/x-amz-json-1.1', 'content-length':'197', 'connection':'keep-alive', ' x-amzn-requestid':*********************************}, 'RetryAttempts':0}}