javascript - dropzone.js 使用内容类型直接上传到 S3

标签 javascript amazon-s3 dropzone.js

我目前正在使用 dropzone.js 通过预签名 URL 将图像上传到 S3。一切正常,除了我无法设置正在上传的文件的内容类型。默认情况下,它们都是使用 binary/octet-stream 上传的,我无法直接在浏览器中查看它们。

我的 S3 预签名策略如下所示:

const policy = s3PolicyV4.generate({
    key: key,
    bucket: process.env.S3_BUCKET,
    contentType: 'multipart/form-data',
    region: process.env.REGION,
    accessKey: process.env.ACCESS_KEY_ID,
    secretKey: process.env.SECRET_ACCESS_KEY,
});

我曾尝试在此处更改 contentType 键,但没有成功,而且我还尝试在进行一些研究后添加它。

conditions: [
   ["starts-with", "$Content-Type", ""]
]

这是我将预签名 URL 的值添加到 dropzone.js 选项的前端代码。

$.ajax({
    type: "POST",
    contentType: "application/json",
    dataType: "json",
    url: api_endpoint,
    cache: false,
    success: function(data) {
        s3_filename_key = data.key;
        $this.options.params = {
            key: data.key,
            acl: data.acl,
            success_action_status: data.success_action_status,
            "X-Amz-Credential": data['X-Amz-Credential'],
            "X-Amz-Algorithm": data['X-Amz-Algorithm'],
            "X-Amz-Date": data['X-Amz-Date'],
            "Policy": data.Policy,
            "X-Amz-Signature": data['X-Amz-Signature']
        }
        done();
    },
    error: function(data) {}
});

当我将 Content-Type 添加到 dropzone 选项时,我得到了这个结果 - Invalid according to Policy: Extra input fields: content-type

这是我的存储桶 CORS 配置。

<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
    <AllowedOrigin>*</AllowedOrigin>
    <AllowedMethod>HEAD</AllowedMethod>
    <AllowedMethod>PUT</AllowedMethod>
    <AllowedMethod>POST</AllowedMethod>
    <AllowedMethod>GET</AllowedMethod>
    <ExposeHeader>ETag</ExposeHeader>
    <ExposeHeader>Content-length</ExposeHeader>
    <AllowedHeader>*</AllowedHeader>
    <AllowedHeader>Content-*</AllowedHeader>
</CORSRule>
</CORSConfiguration>

最佳答案

尝试添加正确的 contentType,您定义的是 enctype。例如:

const policy = s3PolicyV4.generate({
 key: key,
 bucket: process.env.S3_BUCKET,
 contentType: 'application/json',
 region: process.env.REGION,
 accessKey: process.env.ACCESS_KEY_ID,
 secretKey: process.env.SECRET_ACCESS_KEY,
});

Multipart/form-data是表单的enctype属性。

关于javascript - dropzone.js 使用内容类型直接上传到 S3,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47338927/

相关文章:

javascript - 如何手动触发 Dropzone 的点击(打开选择文件对话框)

dropzone.js - DropzoneJS 缩略图宽度和拇指高度不起作用

javascript - Reactjs dropzone未将所有拖放的文件上传到reactjs中的firebase firestore数据库

javascript - jquery dom explorer代码的优化

javascript - 如何重置或清除 Jest 中的 spy ?

amazon-s3 - 亚马逊 AWS S3 强制下载 Mp3 文件而不是流式传输

amazon-web-services - 配置 Cloudformation 以使用 Cloudfront 和 S3 向 GET/subdirectoryserve/subdirectory/index.html 发出请求

amazon-web-services - 使用 S3 从移动应用程序保存图像

javascript - 将特定 div 从嵌套 div 中移出

javascript - Django url重写并从Javascript传递参数