不再使用这个 HTML 表单:
<form action="https://s3.us-east-1.amazonaws.com/BUCKET" method="post" encType="multipart/form-data">
<input type="hidden" name="key" value="${filename}" /><br />
<input type="hidden" name="Content-Type" value="image/jpeg" /><br />
<input type="hidden" name="x-amz-server-side-encryption" value="AES256" />
<input type="hidden" name="X-Amz-Credential" value="MY_CERDENTIALS" />
<input type="hidden" name="X-Amz-Algorithm" value="AWS4-HMAC-SHA256" />
<input type="hidden" name="X-Amz-Date" value="20180817T040045Z" />
<input type="hidden" name="Policy" value='MY_POLICY' />
<input type="hidden" name="X-Amz-Signature" value="MY_SIGN" />
File:
<input type="file" name="file" /> <br />
<input type="submit" name="submit" value="Upload to Amazon S3" />
</form>
我想在 javascript 中使用 ASW SDK 方法 putObject
。我设法创建了这段代码:
AWS.config.update({
endpoint: new AWS.Endpoint('https://s3.amazonaws.com'),
accessKeyId: 'MY_ID', // the app does not run on AWS, so I need credentials
secretAccessKey: 'MY_SECRET_KEY',
s3ForcePathStyle: true,
});
AWS.config.region = "us-east-1";
const params = {
params:{
Bucket: 'ballot-box',
}
}
var bucket = new AWS.S3(params);
const requestParams = {
Key: 'test.png',
ContentType: 'image/jpeg',
Body: file
}
bucket.putObject(requestParams,function(err,file){
if(err)
reject({error: err})
else
resolve({image: encode(file.Body)})
我现在的问题是,我不知道应该将策略、X-Amz-Signature、X-Amz-Date、X--Amz-Algorithm、X-Amz-Credential、x-amz- 放在哪里以及如何放置服务器端加密和 X-Amz-Date。
编辑:
我的存储桶的 CORS 配置:
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>*</AllowedOrigin>
<AllowedMethod>GET</AllowedMethod>
<AllowedMethod>HEAD</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>
最佳答案
从 browser-based upload via POST 移动时对于 JavaScript SDK,您无需提供 Policy、X-Amz-Signature、X-Amz-Date、X--Amz-Algorithm、X-Amz-Credential 或 X-Amz-Date。
如果需要,您可以提供 x-amz-server-side-encryption,您可以通过 ServerSideEncryption:“AES256”在 requestParams 中执行此操作。
关于javascript - AWS SDK S3-如何在 putObject 方法中包含凭据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51903981/