Python:Amazon S3无法获得桶:403 Forbidden说

day*_*mer 14 python amazon-s3 boto

我在Amazon S3中为我的组织提供了一个桶,看起来像 mydev.orgname

  • 我有一个Java应用程序,可以使用凭据连接到Amazon S3,并可以连接到S3,创建,读取文件

  • 我有一个要求,即应用程序从同一个存储桶中读取Python中的数据.所以我正在使用boto.

我在oder中执行以下操作以获取存储桶

>>> import boto
>>> from boto.s3.connection import S3Connection
>>> from boto.s3.key import Key
>>> 
>>> conn = S3Connection('xxxxxxxxxxx', 'yyyyyyyyyyyyyyyyyyyyyy')
>>> conn
S3Connection:s3.amazonaws.com
Run Code Online (Sandbox Code Playgroud)

现在,当我尝试获取存储桶时,我发现错误

>>> b = conn.get_bucket('mydev.myorg')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Library/Python/2.7/site-packages/boto/s3/connection.py", line 389, in get_bucket
    bucket.get_all_keys(headers, maxkeys=0)
  File "/Library/Python/2.7/site-packages/boto/s3/bucket.py", line 367, in get_all_keys
    '', headers, **params)
  File "/Library/Python/2.7/site-packages/boto/s3/bucket.py", line 334, in _get_all
    response.status, response.reason, body)
boto.exception.S3ResponseError: S3ResponseError: 403 Forbidden
<?xml version="1.0" encoding="UTF-8"?>
<Error><Code>AccessDenied</Code><Message>Access Denied</Message><RequestId>EEC05E43AF3E00F3</RequestId><HostId>v7HHmhJaLLQJZYkZ7sL4nqvJDS9yfrhfKQCgh4i8Tx+QsxKaub50OPiYrh3JjQbJ</HostId></Error>
Run Code Online (Sandbox Code Playgroud)

但是从Java应用程序开始,一切似乎都有效.

我在这里做错了吗?

Pav*_*pin 40

为用户提供"更强大的作用"并不是正确的解决方案.这只是boto库使用的问题.显然,使用Java S3库时不需要额外的权限.

在这种情况下使用boto的正确方法是:

b = conn.get_bucket('my-bucket', validate=False)
k = b.get_key('my/cool/object.txt') # will send HEAD request to S3
...
Run Code Online (Sandbox Code Playgroud)

基本上,boto默认情况下(这是他们自己的错误),假设您想要与S3存储桶交互.当然,有时您确实需要,但是您应该使用具有S3存储桶操作权限的凭据.但更常用的用例是与S3对象进行交互,在这种情况下,您不需要任何特殊的桶级权限,因此使用了validate=Falsekwarg.


day*_*mer 0

在赋予我的“用户”更强大的角色后,这个错误就消失了。表示用户获得了 get_bucket 的权限

  • 3年了,这个答案仍然有0票。我坚持认为这是一条评论而不是答案。更具体地说,**答案**会说明更改了哪些权限,而不是“更强的角色”。但它仍然是**错误的解决方案**(对于您可以控制代码的情况)。[最高票数答案](/sf/answers/1014346791/) 是正确的解决方案(给出相同的警告),因为它可以解决 boto 中的意外行为。 (3认同)