到目前为止,我已经在网上搜索了两天多,可能已经浏览了大部分在线记录的场景和变通方法,但到目前为止,没有一个对我有用。

我使用的是AWS SDK for PHP V2.8.7,运行在PHP 5.3上。

我试图连接到我的亚马逊S3桶与以下代码:

// Create a `Aws` object using a configuration file
$aws = Aws::factory('config.php');

// Get the client from the service locator by namespace
$s3Client = $aws->get('s3');

$bucket = "xxx";
$keyname = "xxx";

try {
    $result = $s3Client->putObject(array(
        'Bucket' => $bucket,
        'Key' => $keyname,
        'Body' => 'Hello World!'
    ));

    $file_error = false;
} catch (Exception $e) {
    $file_error = true;

    echo $e->getMessage();

    die();
}

我的config.php文件如下:

return [
    // Bootstrap the configuration file with AWS specific features
    'includes' => ['_aws'],
    'services' => [
        // All AWS clients extend from 'default_settings'. Here we are
        // overriding 'default_settings' with our default credentials and
        // providing a default region setting.
        'default_settings' => [
            'params' => [
                'credentials' => [
                    'key'    => 'key',
                    'secret' => 'secret'
                ]
            ]
        ]
    ]
];

它产生以下错误:

我们计算的请求签名与您提供的签名不匹配。检查您的密钥和签名方法。

我已经检查了我的访问密钥和秘密至少20次,生成了新的,使用不同的方法来传递信息(即配置文件和在代码中包含凭据),但目前没有任何工作。


当前回答

在我的情况下,我使用s3.getSignedUrl('getObject')当我需要使用s3.getSignedUrl('putObject')(因为我使用PUT上传我的文件),这就是为什么签名不匹配。

其他回答

我在使用s3的Cloudfront后端遇到了同样的问题,我的解决方案是在Cloudfront origin策略中不发送“Host”标头。

希望它能解决别人的问题。

问候, 克里希纳k

当我故意给出了错误的有价值的密钥“secret”时,它给出了这个错误。我期待一些有效的错误消息细节,如“身份验证失败”或其他

我也面临着同样的问题。导致问题的代码片段:

<iframe title="PDF Viewer" src={`${docPdfLink}&embed=true`} />

对我来说,有两个问题

在链接的末尾使用embed会导致签名不匹配,所以问题就来了。 S3中的文件具有应用程序/pdf以外的内容类型,因此我甚至在固定第一点后无法渲染pdf。

下面是我在代码中所做的:

<iframe title="PDF Viewer" src={docPdfLink} />

这里是s3 bucket: s3文件内容类型 此外,我们还需要确保无论何时向s3添加或创建pdf,它都应该有应用程序内容application/pdf

大多数情况下,这是因为错误的密钥(AWS_SECRET_ACCESS_KEY)。请交叉验证您的AWS_SECRET_ACCESS_KEY。希望它能起作用…

在我的情况下,桶名是错误的,它包括密钥的第一部分(bucketxxx/keyxxx) -签名没有任何问题。