2016-10-04 141 views
3

我第一次尝试使用PHP AWS SDK(“aws/aws-sdk-php”:“^ 3.19”)来使用S3。PHP亚马逊SDK,S3桶拒绝访问

我创建了一个桶: 'myfirstbucket-jeremyc'

我创建的策略:

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

予应用的策略的一组,然后在创建用户 'S3-myfirstbucket-jeremyc'这个组。

我的PHP代码:

<?php 
use Aws\S3\S3Client; 
use Aws\S3\Exception\S3Exception; 

error_reporting(E_ALL); 

require(__DIR__ . '/vendor/autoload.php'); 

$s3Client = S3Client::factory([ 
    'credentials' => [ 
     'key' => $_SERVER['AWS_S3_CLIENT_KEY'], 
     'secret' => $_SERVER['AWS_S3_CLIENT_SECRET'] 
    ], 
    'region' => 'eu-west-1', 
    'version' => 'latest', 
    'scheme' => 'http' 
]); 

$result = $s3Client->putObject(array(
    'Bucket' => 'myfirstbucket-jeremyc', 
    'Key' => 'text.txt', 
    'Body' => 'Hello, world!', 
    'ACL' => 'public-read' 
    )); 

,但我得到这个错误:

Error executing "PutObject" on " http://s3-eu-west-1.amazonaws.com/myfirstbucket-jeremyc/text.txt "; AWS HTTP error: Client error: PUT http://s3-eu-west-1.amazonaws.com/myfirstbucket-jeremyc/text.txt resulted in a 403 Forbidden response

你知道我错了?

在此先感谢!

回答

3

您正在设置新对象的ACL,但您不允许使用​​。

+1

谢谢!它通过评论ACL的行或在策略中添加“s3:PutObjectAcl”来工作。 – JeremyC