【发布时间】:2019-09-15 06:58:16
【问题描述】:
我希望允许公共用户在其浏览器上查看位于 AWS S3 存储桶上的 HTML 文件。这些 HTML 文件通过 node.js 创建并上传到我的 S3 存储桶,并生成链接到该文件的 URL。
我正在使用这种方法上传 HTML 文件:
s3.upload({
Bucket: bucket,
Key: "HTMLFiles/file.HTML",
Body: fileStream,
ACL: 'public-read'
}, function (err, data) {
if (err) {
console.log("Error: ", err);
}
if (data) {
console.log("Success: ", data.Location);
}
}).on('httpUploadProgress', event => {
console.log(`Uploaded ${event.loaded} out of ${event.total}`);
});
脚本运行时,生成的 URL 如下所示:
https://bucket-name.s3.region.amazonaws.com/HTMLFiles/file.html
(显然这只是一个示例 URL,而不是实际 URL)
当用户访问此 URL 时,浏览器不会查看 HTML 文件,而是下载该文件。
如何指定此文件是要在浏览器上加载和查看,而不是下载?
【问题讨论】:
-
您也可以通过在存储桶上启用网站托管来实现此目的;我们定期使用非常相似的方法将文件上传到 S3,并且我们不传递 ContentType,它们直接从 S3 存储桶以 HTML 文件的形式提供。
标签: html node.js amazon-web-services amazon-s3 permissions