S3 的 AWS AccessDeniedException Laravel

AWS AccessDeniedException with Laravel for S3

当我尝试使用 Laravel 将对象放入 S3 存储桶时,我从 AWS PHP SDK 获得了一个 AccessDeniedException。我已经在 application/config/packages/aws/aws-sdk-php-laravel/config.php 中配置了密钥、机密和区域。然后我尝试使用以下代码执行一个简单的 putObject:

try {
    AWS::get('s3')->putObject(array(
        'Bucket' => Config::get('settings.AWS_BUCKET'),
        'Key'    => 'hello_.txt',
        'Body'   => 'hi',
        'ACL'    => 'public-read'
    ));

    return 'great success';
} catch (Exception $e) {
    return $e;
}

正如你所期望的那样,我一开始问这个问题,失败了,returns 像这样(请求 ID 每次都在变化):

Aws\S3\Exception\AccessDeniedException: AWS Error Code: AccessDenied, Status Code: 403, AWS Request ID: CA0E8181A5F2D740, AWS Error Type: client, AWS Error Message: Access Denied, User-Agent: aws-sdk-php2/2.7.20 Guzzle/3.9.2 curl/7.40.0 PHP/5.4.37 Laravel/4.2.17 L4MOD/1.1.0

据我所知,我只是被拒绝访问存储桶。如果我更改密钥或机密,我将分别得到 InvalidAccessKeyIdExceptionSignatureDoesNotMatchException。我在这里错过了什么?

我终于发现,如果我在 IAM 下的用户许可下添加 AmazonS3FullAccess 策略,应用程序终于可以运行,我能够创建项目并将项目上传到存储桶。