我想执行一个预签名的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文档
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作为组件库: 此请求失败,出现以