如何上传文件到授予公共访问权限的AWS S3?

12

我正在使用AWS示例代码将文件上传到S3,但是当它们被上传时,即使桶对所有人都是公共的,它们也没有任何人可以访问,唯一的方法是在S3控制台上手动设置文件以授予公共访问权限。

我的服务:

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    if (intent != null && intent.getStringExtra(INTENT_KEY_NAME) != null) {
        final String key = intent.getStringExtra(INTENT_KEY_NAME);
        final File file = (File) intent.getSerializableExtra(INTENT_FILE);
        final String transferOperation = intent.getStringExtra(INTENT_TRANSFER_OPERATION);
        TransferObserver transferObserver;

        switch (transferOperation) {
            case TRANSFER_OPERATION_DOWNLOAD:
                Log.d(TAG, "Downloading " + key);
                transferObserver = transferUtility.download("aws-MYBUCKET", key, file);
                transferObserver.setTransferListener(new DownloadListener());
                break;
            case TRANSFER_OPERATION_UPLOAD:
                Log.d(TAG, "Uploading " + key);
                transferObserver = transferUtility.upload("aws-MYBUCKET", key, file);
                transferObserver.setTransferListener(new UploadListener());
                break;
        }
        return START_STICKY;
    } else return START_NOT_STICKY;
1个回答

19

你应该创建一个Bucket Policy。这可以为整个存储桶或部分存储桶授予公共访问权限。

来自Amazon Simple Storage Service的桶策略示例

{
  "Version":"2012-10-17",
  "Statement":[
    {
      "Sid":"AddPerm",
      "Effect":"Allow",
      "Principal": "*",
      "Action":["s3:GetObject"],
      "Resource":["arn:aws:s3:::examplebucket/*"]
    }
  ]
}

这比在单个对象上授予权限更可取。


最终这是一个对我有效的解决方案。谢谢! - Abhijeet K.
由于某种原因,我认为版本可以接受今天的日期,但似乎它只接受示例中给出的日期。 - Sandeep
是的,版本实际上是一个版本号。CloudFormation不使用像1.0、1.1等值,而是使用日期。这种方式可能有点令人困惑。虽然它看起来像一个旧日期,但这没关系,因为从那时起所有的更改都是向后兼容的。 - John Rotenstein

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接