使用
boto
,我可以通过传递 anon=
关键字参数来连接到公共 S3 存储桶,而无需凭据。
s3 = boto.connect_s3(anon=True)
这可以通过
boto3
实现吗?
是的。您的凭据用于签署您发出的所有请求,因此您需要做的是将客户端配置为根本不执行签名步骤。您可以按如下方式操作:
import boto3
from botocore import UNSIGNED
from botocore.client import Config
s3 = boto3.client('s3', config=Config(signature_version=UNSIGNED))
# Use the client
禁用签名
import boto3
from botocore.handlers import disable_signing
resource = boto3.resource('s3')
resource.meta.client.meta.events.register('choose-signer.s3.*', disable_signing)
从当前的 boto3 版本(1.9.168)开始,这些似乎都不起作用。这个 hack(由 botocore 上未修复的 github 问题提供)似乎确实有效:
client = boto3.client('s3', aws_access_key_id='', aws_secret_access_key='')
client._request_signer.sign = (lambda *args, **kwargs: None)