10

我正在编写代码以向使用aws-sdk gem 的所有用户授予 READ 权限。在 gem 的文档中,我发现了以下内容:

bucket.objects.each do |object|
  puts object.key
  acl = object.acl
  acl.grant(:read).to("TODO: how can I specify 'ALL'???")
  object.acl = acl.to_xml
end

这一切都说得通,但是我不太确定如何告诉所有用户授予读取权限?

4

1 回答 1

28

您拥有的示例可以工作,但更适合复杂的 ACL(访问控制列表)。Amazon S3 有许多可用于对象的标准 acl。以下代码段将更新存储桶中所有对象的 ACL,以便任何人都可以读取它们。

bucket.objects.each{|obj| obj.acl = :public_read }

或者,您可以在上传(或复制)对象时为其设置 ACL。

# upload a file and set the acl so the world can download it
obj = bucket.objects['object-key'].write(file, :acl => :public_read)

puts obj.public_url
#=> 'https://..."
于 2012-10-19T03:57:48.613 回答