我已经测试了将图像上传到机器上的s3的功能,但当我在ec2上投入生产时,由于一个奇怪的原因,它不起作用。
这就是错误:
CredentialsException in InstanceProfileProvider.php line 79:Error retrieving credentials from the instance profile metadata server. (Client error: 404)
这是代码:
$destinationPath = 'images/institutions/logos';
$extension = $data['int_logo']->getClientOriginalExtension();
$keyname = $destinationPath.'/'.$username.'.'.$extension;
$bucket = "*****";
$filepath = $data['int_logo'];
$s3 = new S3Client([
'region' => 'us-west-2',
'version' => '2006-03-01',
'scheme' => 'http'
]);
$result = $s3->putObject(array(
'Bucket' => $bucket,
'Key' => $keyname,
'SourceFile' => $filepath,
'ACL' => 'public-read'
));
return $result['ObjectURL'];
}
这是我的s3政策:
{
"Version": "2012-10-17",
"Id": "*******",
"Statement": [
{
"Sid": "******",
"Effect": "Allow",
"Principal": "*",
"Action": [
"s3:GetObject",
"s3:PutObjectAcl",
"s3:PutObject"
],
"Resource": "arn:aws:s3:::****/*"
}
]}
我不知道为什么它会在凭据上出错,我没有使用任何身份验证,每个人都可以在这个bucket上放一个文件。它在我的机器上100%工作。
建立匿名连接的解决方案:
更改:
$s3 = new S3Client([
'region' => 'us-west-2',
'version' => '2006-03-01',
'scheme' => 'http',
]);
收件人:
$s3 = new S3Client([
'region' => 'us-west-2',
'version' => '2006-03-01',
'scheme' => 'http',
'credentials' => false
]);
我仍然不知道为什么我的本地机器可以建立连接,但如果没有这条线,ec2服务器就无法做到这一点。
我过去也遇到过同样的问题。我最终不得不输入以下代码,这对我很有效:
$s3->path_style = true;