在EC2实例上使用PHP将文件上载到s3时抛出凭据错误,但可以在本地工作


Upload file to s3 with PHP on a EC2 instance throw credentials error, but works locally

我已经测试了将图像上传到机器上的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;
相关文章: