Pry*_*die 6 python boto amazon-cloudfront
我已经编写了以下代码来使用boto对URL进行签名,但是,我无法访问已签名的URL.任何帮助将不胜感激.
con = cloudfront.CloudFrontConnection(
settings.AWS_USER_DETAILS.access_key_id,
settings.AWS_USER_DETAILS.secret_key_id,
)
identities = con.get_all_origin_access_identity()
if len(identities) < 1:
oai = con.create_origin_access_identity(
'cv-oai',
'OAI signing iOS video requests'
)
else:
oai = con.get_all_origin_access_identity()[0]
distro_summary = con.get_all_distributions()[0]
distro_info = con.get_distribution_info(distro_summary.id)
bucket = boto.connect_s3(
settings.AWS_USER_DETAILS.access_key_id,
settings.AWS_USER_DETAILS.secret_key_id,
host='s3-eu-west-1.amazonaws.com'
).get_bucket(u'cv-video')
key_str = video.video_url.split('/')[-1]
key = bucket.get_key(key_str)
key.add_user_grant("READ", oai.s3_user_id)
distro = distro_summary.get_distribution()
# For local testing
if ip_addr == '127.0.0.1':
ip_addr = None
private_key_string = open(settings.CF_PRIV_KEY_LOC).read()
print private_key_string
signed_url = distro.create_signed_url(
"https://%s/%s" % (distro_info.domain_name, key_str),
'APKAI3I3QZ7I73OIQIXA',
expire_time=int(time.time()) + video.video_length + 5 * 60,
#valid_after_time=None,
#ip_address=ip_addr,
#policy_url=None,
private_key_string=private_key_string
)
Run Code Online (Sandbox Code Playgroud)
错误:
更新:这是访问上述代码生成的URL时收到的错误.我无法找到CloudFront错误的文档来确定为什么会发生这种情况.
<Error>
<Code>InvalidKey</Code>
<Message>Unknown Key</Message>
</Error>
Run Code Online (Sandbox Code Playgroud)
示例网址:
密钥对肯定是活跃的:

只有一个Origin Access Identity和一个发行版:
[<boto.cloudfront.identity.OriginAccessIdentitySummary object at 0x10f356110>]
[<boto.cloudfront.distribution.DistributionSummary object at 0x10f356090>]
Run Code Online (Sandbox Code Playgroud)
小智 4
我遇到过同样的问题。
我想知道couldfront和s3是否还没有逻辑地连接到“原始访问身份”。这是 cloudfront 用于从 S3 提取内容的身份,并使用您指定的私钥对验证签名。
果然,这就是问题所在。禁用对底层 S3 存储桶的公共访问,然后告诉 AWS 使用适当的身份,然后重试您的代码。
以下是来自网络的方法:
在 CloudFront 仪表板 ( https://console.aws.amazon.com/cloudfront/home ) 中,单击左侧的“分发”以查看所有发行版。选择您想要的,单击 [i] 图标了解更多信息。从那里,单击 [Origins] 选项卡,然后选择存储桶旁边的单选按钮。单击它,将出现一个编辑按钮。单击编辑。在出现的新面板中选择“限制存储桶访问”。该站点将提示您选择哪个访问身份。选择您创建的身份。单击“是,编辑”保存更改。
祝你好运!
| 归档时间: |
|
| 查看次数: |
2243 次 |
| 最近记录: |