使用 Rails 和回形针的适用于 s3 的简单 Amazon IAM 策略



为了允许用户my-user访问名为 my-bucket 的 Amazon S3 存储桶,我的 IAM 策略应该是什么样子?

目前,我已将以下策略分配给my-user

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": ["s3:ListBucket"],
      "Resource": ["arn:aws:s3:::my-bucket"]
    },
    {
      "Effect": "Allow",
      "Action": [
        "s3:PutObject",
        "s3:GetObject",
        "s3:DeleteObject"
      ],
      "Resource": ["arn:aws:s3:::my-bucket/*"]
    }
  ]
}

我从以下链接上的"示例 1"中获得了此策略:

http://blogs.aws.amazon.com/security/post/Tx3VRSWZ6B3SHAV/Writing-IAM-Policies-How-to-grant-access-to-an-Amazon-S3-bucket

在我的production.rb文件中,我已经实现了配置设置来告诉回形针使用 S3:

config.paperclip_defaults = {
  :storage => :s3,
  :s3_credentials => {
    :bucket => 'my-bucket',
    :access_key_id => ENV['AWS_ACCESS_KEY_ID'],
    :secret_access_key => ENV['AWS_SECRET_ACCESS_KEY']
  }
}

当我尝试使用我的应用程序上传照片时,我收到AWS::S3::Errors::AccessDenied异常。

奇怪的是,如果我加载 rails 控制台,并运行以下代码手动上传文件,它可以正常工作:

s3 = AWS::S3.new(access_key_id: ENV['AWS_ACCESS_KEY_ID'], secret_access_key: ENV['AWS_SECRET_ACCESS_KEY'])
bucket = s3.buckets['my-bucket']
obj = bucket.objects['new_file']
obj.write(Pathname.new('/path/to/file'))

这会将文件正确上传到我的 S3 存储桶。我很困惑为什么我显然有权以这种方式上传文件,但是当我尝试使用相同的凭据通过回形针执行此操作时,我收到权限被拒绝错误。

更令人困惑的是,当我将AdministratorAccess策略分配给my-user时,回形针能够成功上传文件。

知道我该如何解决这个问题吗?

解决方案在这里: https://stackoverflow.com/a/19185045/736864

当回形针将文件上传到 S3 时,它还会尝试将文件设置为可公开查看,这意味着需要向用户授予设置权限的访问权限。将s3:PutObjectAcl权限添加到我的 IAM 策略解决了此问题。

最新更新