2015-10-20 18 views
6

Bir dosyadan bir paket indiren çok basit bir komut dosyası var. Dosya KMS şifreli anahtarları kullanıyor, politikalarım ve rollerim doğru şekilde kuruldu ancak hala hata alıyorum.Boto3 download_file'ı AWS KMS ile nasıl kullanıyorsunuz?

Kod

#!/usr/bin/env python 
import boto3 
s3_client = boto3.client('s3') 
s3_client.download_file('testtesttest', 'test.txt', '/tmp/test.txt') 

Hata

Traceback (most recent call last): 
    File "./getfile.py", line 4, in <module> 
s3_client.download_file('testtesttest', 'test.txt', '/tmp/test.txt') 
File "/usr/local/lib/python2.7/dist-packages/boto3/s3/inject.py", line 91, in download_file 
extra_args=ExtraArgs, callback=Callback) 
File "/usr/local/lib/python2.7/dist-packages/boto3/s3/transfer.py", line 659, in download_file 
extra_args, callback) 
File "/usr/local/lib/python2.7/dist-packages/boto3/s3/transfer.py", line 674, in _download_file 
self._get_object(bucket, key, filename, extra_args, callback) 
File "/usr/local/lib/python2.7/dist-packages/boto3/s3/transfer.py", line 698, in _get_object 
extra_args, callback) 
File "/usr/local/lib/python2.7/dist-packages/boto3/s3/transfer.py", line 712, in _do_get_object 
**extra_args) 
File "/usr/local/lib/python2.7/dist-packages/botocore/client.py", line 301, in _api_call 
return self._make_api_call(operation_name, kwargs) 
File "/usr/local/lib/python2.7/dist-packages/botocore/client.py", line 386, in _make_api_call 
raise ClientError(parsed_response, operation_name) 
botocore.exceptions.ClientError: An error occurred (InvalidArgument) when calling the GetObject operation: Requests specifying Server Side Encryption with AWS KMS managed keys require AWS Signature Version 4. 
+0

Gelecek okuyucular için not: 's3v4' varsayılan değerdir, bu nedenle bir yapılandırma dosyasından veya ortamdan bir yere koymadıkça onu açıkça belirtmeniz gerekmez. Boto3.client ('s3'). Meta.config.signature_version' seçeneğini işaretleyin. – wim

cevap

12

dışarı düşündüm

Kod

#!/usr/bin/env python 
import boto3 
from botocore.client import Config 
s3_client = boto3.client('s3', config=Config(signature_version='s3v4')) 
s3_client.download_file('testtesttest', 'test.txt', '/tmp/test.txt') 
+0

TEŞEKKÜR EDERİZ! Bunu bir saatin daha iyi bir kısmı için çözmeye çalışıyorum. Günümü çok daha kolaylaştırdın. – Valdogg21

+0

Hayır Sorun, Sevindim Yardım ettim! @ Valdogg21 – Laurence

+0

Cevabınız, cevabı kabul ederse :) – Dawny33

4

Ayrıca kms tuşlarını kullanarak s3 dosyasına nasıl dosya yükleyeceğinizi de bilmek isteyebilirsiniz.

s3_client = boto3.client('s3', config=Config(signature_version='s3v4')) 
s3_client.upload_file(filename, bucketname, objectkey, ExtraArgs={"ServerSideEncryption": "aws:kms", "SSEKMSKeyId": <somekmskeyid>}) 

KMS anahtarı kimliği girmezseniz - o zaman varsayılan olarak s3 kms ana anahtarı kullanır.