gpt4 book ai didi

python - 无法使用 boto 签署云端 URL

转载 作者:太空狗 更新时间:2023-10-30 00:07:20 26 4
gpt4 key购买 nike

我已经编写了以下代码来使用 boto 对 URLS 进行签名,但是,我无法访问已签名的 URLS。任何帮助将不胜感激。

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
)

错误:

更新:这是访问上述代码生成的 URL 时收到的错误。我无法找到 CloudFront 错误的文档来确定为什么会发生这种情况。

<Error>
<Code>InvalidKey</Code>
<Message>Unknown Key</Message>
</Error>

示例网址:

https://d1xvt07pr26drp.cloudfront.net/2iwjz3wn9atqlfw4.mov?Expires=1388705061&Signature=auPWW-X1LzZJkPxJ5YPCqQMatchbAb3BxCWTG5oMY78G6LrH0sZiQL6EKdCX-l3Fi9E475b11uFL~HnxfBUY9QqQH86478QU5BnpmR-U7uEikRs7kTDWOVj4Riv3PHUmjmzlBW8xU7-n9C0m2UZSXedPsYYFdPoWHH0VLlyKk2TzgYydLqu~jtq0iNdmz-C9TOgUCaICiMYi082AVc7bt6xTfVszA9BeAD4KLKnr42raFDLojbA78Q-7bLNA2CiStdT-8BblQOQ5IXUCxYdkw7ak0vp77vER1pCG9cEBkCHD~9dZccyQEGJApO~ax4D5wDtCpeQj3l0pW6kYNUlP8Q__&Key-Pair-Id=APKAI3I3QZ7I73OIQIXA

key 对肯定是活跃的:

Key Pair is active

只有一个 Origin Access Identity 和一个 distribution:

[<boto.cloudfront.identity.OriginAccessIdentitySummary object at 0x10f356110>]
[<boto.cloudfront.distribution.DistributionSummary object at 0x10f356090>]

最佳答案

我遇到了同样的问题。

我想是不是 couldfront 和 s3 还没有逻辑连接到“源访问身份”。这是 cloudfront 用于从 S3 中提取内容的身份,使用您指定的私钥对验证签名。

果然,这就是问题所在。禁用对底层 S3 存储桶的公共(public)访问,然后告诉 AWS 使用适当的身份,然后再次尝试您的代码。

这是来自网络的方法:

在 CloudFront 仪表板 ( https://console.aws.amazon.com/cloudfront/home ) 中,单击左侧的“分发”以查看您的所有发行版。选择您想要的,单击 [i] 图标了解更多信息。从那里,单击 [Origins] 选项卡并选择存储桶旁边的单选按钮。单击它,将出现一个编辑按钮。单击编辑。在出现的新面板中选择“限制存储桶访问”。该站点将提示您使用哪种访问身份。选择您创建的身份。单击“是,编辑”以保存您的更改。

祝你好运!

关于python - 无法使用 boto 签署云端 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20893885/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com