使用Laravel for S3的AWS AccessDeniedException

时间:2015-03-04 23:00:59

标签: php laravel amazon-web-services amazon-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;
}

正如您在开始时提出这个问题时所期望的那样,失败并返回类似这样的内容(请求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。我在这里缺少什么?

1 个答案:

答案 0 :(得分:7)

我终于发现如果我在IAM下的用户许可下添加了AmazonS3FullAccess策略,那么应用程序终于可以工作了,我就可以创建项目并将其上传到存储桶。