当前位置: 首页 > 面试题库 >

如何在Go中将预签名的POST上传到AWS S3?

能远
2023-03-14
问题内容

我想执行一个预签名的POST以将文件上传到AWSS3存储桶-如何在Go中完成?

请注意,这与通过PUT进行预签名上传不同。


问题答案:

因此,为了帮助他人,我将自己回答问题,并提供一些代码来帮助可能遇到相同问题的其他人。

可在此处找到Google App Engine呈现预签名POST表单的示例网络应用。

和一个小型图书馆,我创建做在Go预签POST。

简而言之,对公共读取的Amazon S3存储桶执行预签名的POST,您需要:

1.将S3存储桶配置为仅允许公共下载。

仅允许公共读取的示例存储桶策略。

{
    "Version": "2012-10-17",
    "Id": "akjsdhakshfjlashdf",
    "Statement": [
        {
            "Sid": "kjahsdkajhsdkjasda",
            "Effect": "Allow",
            "Principal": {
                "AWS": "*"
            },
            "Action": "s3:GetObject",
            "Resource": "arn:aws:s3:::BUCKETNAMEHERE/*"
        }
    ]
}

2.为允许上传的HTTP POST创建一个策略。

AWSS3文档

示例POST策略模板,带有过期时间,可以将特定密钥上载到特定存储桶中,并允许公众读取访问。

{ "expiration": "%s",
    "conditions": [
        {"bucket": "%s"},
        ["starts-with", "$key", "%s"],
        {"acl": "public-read"},

        {"x-amz-credential": "%s"},
        {"x-amz-algorithm": "AWS4-HMAC-SHA256"},
        {"x-amz-date": "%s" }
    ]
}

3.使用S3存储桶所有者的凭据生成并签名策略。

AWS文档

  • 填写正确的值以表示到期时间,存储段,密钥,凭据和日期。
  • base64对策略进行编码。
  • HMAC-SHA256获取签名的策略。
  • 十六进制编码签名。

4.构造并发布多部分表单数据

AWS S3文档

现在,您要么生成HTML表单,然后自动获取正确的多部分表单数据请求,如上面的链接中所述。

我想在Go中手动完成此操作,所以这里是操作方法。

无论哪种方式,您都需要提供在步骤2和3中创建的POST策略中指定的所有部分。请求中除了强制性字段(策略中不包含)外,也不能有其他字段。

还指定了字段的顺序,并且它们都是HTTP POST请求中的多部分字段。

func Upload(url string, fields Fields) error {
    var b bytes.Buffer
    w := multipart.NewWriter(&b)
    for _, f := range fields {
            fw, err := w.CreateFormField(f.Key)
            if err != nil {
                    return err
            }
            if _, err := fw.Write([]byte(f.Value)); err != nil {
                    return err
            }
    }
    w.Close()

    req, err := http.NewRequest("POST", url, &b)
    if err != nil {
            return err
    }
    req.Header.Set("Content-Type", w.FormDataContentType())

    client := &http.Client{}
    res, err := client.Do(req)
    if err != nil {
            return err
    }
    if res.StatusCode != http.StatusOK {
            err = fmt.Errorf("bad status: %s", res.Status)
    }
    return nil
}


 类似资料:
  • 我已经使用我的后端代码生成了预先设计的URL,然后使用该URL上传了一个在会话期间录制的视频。我在前端使用下面的代码(React JS)来上传视频,预检似乎失败了,因为403禁止,post请求失败了,因为cors错误。请查看以下详细信息: 使用的代码: 控制台错误:访问“获取时间”https://xxxxxxxxxx“起源”http://localhost:5000'已被CORS策略阻止:对飞行前

  • 问题内容: 我正在尝试使用预签名的URL将文件上传到Amazon的S3。我从生成URL的服务器获取URL,并将其作为JSON对象的一部分发送给我。我将URL作为字符串获取,如下所示: https://com-example-mysite.s3-us- east-1.amazonaws.com/userFolder/ImageName?X-Amz-Security- Token=xxfooxx%2F

  • 嗨,当我尝试使用vue应用程序中预先指定的url将图像上传到我的amazon aws bucket时,我收到了400个错误请求。我已经成功生成了一个预先签名的url,但我无法使用它将图像发布到我的bucket。 获取预签名网址的路线 Vue client Vuex操作发布到预先指定的url Aws CORS许可 我得到“请求失败,状态代码400”错误。

  • 我试图使用S3预签名的PUT url执行文档上传。我使用java AWSSDK(GeneratePresignedUrlRequest.java)生成url。此url生成代码位于AWS API网关后面的lambda函数中。 然而,当我在Postman中复制生成的url时,我遇到了以下错误 生成的url是“https:// 关于在生成url时需要更正的内容,有什么建议吗?

  • 我正在使用Rails后端构建一个Vue应用程序。我正在关注一些在线文章,其中提出了一个工作流程,我: 让我的Rails API生成一个预签名的S3URL 我通过Vue应用程序中的API请求获取 我使用该请求中的数据将实际图像直接发布到S3 前两个步骤工作正常,但是我很难理解如何在请求类型为“多部分/表单数据”的请求中包含文件数据。 我的代码如下,我使用vuetify作为组件库: 此请求失败,出现以