s3.getSignedUrl ResponseContentDisposition 参数不起作用



我已成功生成一个签名 url,然后我可以在有限的时间内使用该 url 从我的 s3 存储桶下载资源。 但是,我正在尝试在参数中使用 ResponseContentDisposition 属性,如下所述:

  1. http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#getSignedUrl-property
  2. http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#getObject-property

不确定我是否做错了,但由于某种原因没有设置标题。 例如,如果我使用从 s3.getSignedURL 返回的 url:

curl -i "https://foo-dev.s3.amazonaws.com/images/foo.jpg?AWSAccessKeyId=AKIAICBHUC26S6B446PQ&Expires=1468359314&Signature=EeBqx1G83oeusarBl2KUbbCCBgA%3D&response-content-disposition=attachment%3B%20filename%3Ddata.jpg"

标题为:

x-amz-id-2: SG9rjYQCcuqgKfjBmMbDQC2CNLcnqBAFzP7zINa99VYUwNijPOm5Ea/5fllZ6cnt/Qti7e26hbE=
x-amz-request-id: 2670068008525B1D
Date: Tue, 12 Jul 2016 21:26:16 GMT
Content-Disposition: inline; filename=foo.jpg
Last-Modified: Tue, 12 Jul 2016 00:47:23 GMT
ETag: "2a8e36651b24769170f4faa429f40f54"
Accept-Ranges: bytes
Content-Type: image/jpeg
Content-Length: 43373
Server: AmazonS3

我正在使用javascript s3 sdk进行设置,如下所示:

function tempRedirect(req, res) {
    var filename = req.params[0];
    var contentDisposition = 'attachment; filename=data.jpg';
    var params = {
        Bucket: S3_BUCKET,
        ResponseContentDisposition: contentDisposition,
        Key: checkTrailingSlash(getFileKeyDir(req)) + filename
    };
    var s3 = new aws.S3(s3Options);
    s3.getSignedUrl('getObject', params, function(err, url) {
        res.redirect(url);
    });
};

文档非常轻巧,我只能找到 PHP 示例,但看起来我确实正确设置了内容处置。

有谁知道这里出了什么问题??

根据 RFC- 2616,您的值格式不正确。

预期的格式为 attachment; filename="funny-cat.jpg" 。 文件名是带引号的字符串。

而且,我最初的假设是 S3 拒绝它无效并默默拒绝替换该值。

随后的测试揭示了意外行为:如果Content-Disposition未与对象一起存储,则&response-content-disposition=...按预期工作,设置响应标头。 但是,如果存在与对象一起存储的标头,则此查询字符串参数不具有"覆盖"该值的记录效果。

相反,&response-content-type=...覆盖对象的存储Content-Type:

这就是一些快速测试为我揭示的内容。

但这似乎是 S3 中的一个错误——或者更准确地说,某种回归。 根据一个支持论坛帖子,该行为实际上是不一致的,有时有效,有时无效。

S3 已意识到此问题,我们正在努力解决它。(2016-07-12)

https://forums.aws.amazon.com/thread.jspa?threadID=235006

最新更新