【发布时间】:2013-11-03 10:18:57
【问题描述】:
我正在尝试将文件上传到我的 Amazon S3 存储桶。 S3 和亚马逊成立。 这是来自亚马逊的错误信息:
查询字符串参数冲突:acl、policy
策略和签名被编码,Crypto.js 用于 Node.js
var crypto=Npm.require("crypto");
我正在尝试使用 Meteor HTTP.post 方法构建 POST 请求。这也可能是错误的。
var BucketName="mybucket";
var AWSAccessKeyId="MY_ACCES_KEY";
var AWSSecretKey="MY_SECRET_KEY";
//create policy
var POLICY_JSON={
"expiration": "2009-01-01T00:00:00Z",
"conditions": [
{"bucket": BucketName},
["starts-with", "$key", "uploads/"],
{"acl": 'public-read'},
["starts-with", "$Content-Type", ""],
["content-length-range", 0, 1048576],
]
}
var policyBase64=encodePolicy(POLICY_JSON);
//create signature
var SIGNATURE = encodeSignature(policyBase64,AWSSecretKey);
console.log('signature: ', SIGNATURE);
这是我与 Meteor 一起使用的 POST 请求:
//Send data----------
var options={
"params":{
"key":file.name,
'AWSAccessKeyId':AWSAccessKeyId,
'acl':'public-read',
'policy':policyBase64,
'signature':SIGNATURE,
'Content-Type':file.type,
'file':file,
"enctype":"multipart/form-data",
}
}
HTTP.call('POST','https://'+BucketName+'.s3.amazonaws.com/',options,function(error,result){
if(error){
console.log("and HTTP ERROR:",error);
}else{
console.log("result:",result);
}
});
我正在对策略和签名进行编码:
encodePolicy=function(jsonPolicy){
// stringify the policy, store it in a NodeJS Buffer object
var buffer=new Buffer(JSON.stringify(jsonPolicy));
// convert it to base64
var policy=buffer.toString("base64");
// replace "/" and "+" so that it is URL-safe.
return policy.replace(/\//g,"_").replace(/\+/g,"-");
}
encodeSignature=function(policy,secret){
var hmac=crypto.createHmac("sha256",secret);
hmac.update(policy);
return hmac.digest("hex");
}
A 无法弄清楚发生了什么。 POST 方法或加密可能已经存在问题,因为我不太了解这些方法。如果有人能指出我正确的方向、正确编码或向 AmazonS3 发送 POST 请求,那将有很大帮助。
(我不喜欢使用 filepicker.io,因为我不想强迫客户也在那里注册。)
提前致谢!!!
【问题讨论】:
-
queryString 和 POST 参数不一样,也许你需要在 GET url 上复制两个被抱怨的参数...
标签: javascript amazon-web-services amazon-s3 meteor