我已成功生成一个签名 url,然后我可以在有限的时间内使用该 url 从我的 s3 存储桶下载资源。 但是,我正在尝试在参数中使用 ResponseContentDisposition 属性,如下所述:
- http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#getSignedUrl-property
- 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