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
据我所知,我只是被拒绝访问存储桶。如果我更改密钥或机密,我将分别得到 InvalidAccessKeyIdException
和 SignatureDoesNotMatchException
。我在这里错过了什么?
我终于发现,如果我在 IAM 下的用户许可下添加 AmazonS3FullAccess 策略,应用程序终于可以运行,我能够创建项目并将项目上传到存储桶。
当我尝试使用 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
据我所知,我只是被拒绝访问存储桶。如果我更改密钥或机密,我将分别得到 InvalidAccessKeyIdException
和 SignatureDoesNotMatchException
。我在这里错过了什么?
我终于发现,如果我在 IAM 下的用户许可下添加 AmazonS3FullAccess 策略,应用程序终于可以运行,我能够创建项目并将项目上传到存储桶。