Encoding Meteor:将图像从URL保存到AWS S3存储
我正在尝试,服务器端,通过它的url(即)从web上获取图像,并使用Meteor、AWS sdk meteorite包以及http Meteor包将此图像保存到我的AWS S3存储桶中 这是我的尝试,它确实将一个文件放入我的bucket(someImageFile.jpg),但该图像文件随后已损坏,无法由浏览器或查看器应用程序显示 可能我对文件的编码有问题。我尝试了许多组合,但都不起作用。此外,我还尝试使用不同的编码添加ContentLength和/或ContentEncoding,如binary、hex、base64(也与Encoding Meteor:将图像从URL保存到AWS S3存储,encoding,amazon-web-services,amazon-s3,get,meteor,Encoding,Amazon Web Services,Amazon S3,Get,Meteor,我正在尝试,服务器端,通过它的url(即)从web上获取图像,并使用Meteor、AWS sdk meteorite包以及http Meteor包将此图像保存到我的AWS S3存储桶中 这是我的尝试,它确实将一个文件放入我的bucket(someImageFile.jpg),但该图像文件随后已损坏,无法由浏览器或查看器应用程序显示 可能我对文件的编码有问题。我尝试了许多组合,但都不起作用。此外,我还尝试使用不同的编码添加ContentLength和/或ContentEncoding,如binar
Buffer.toString(“base64”)
结合使用),但均无效。如有任何建议,将不胜感激
这在我的服务器端代码中:
var url="http://www.skrenta.com/images/stackoverflow.jpg";
HTTP.get(url, function(err, data) {
if (err) {
console.log("Error: " + err);
} else {
//console.log("Result: "+JSON.stringify(data));
//uncommenting above line fills up the console with raw image data
s3.putObject({
ACL:"public-read",
Bucket:"MY_BUCKET",
Key: "someImageFile.jpg",
Body: new Buffer(data.content,"binary"),
ContentType: data.headers["content-type"], // = image/jpeg
//ContentLength: parseInt(data.headers["content-length"]),
//ContentEncoding: "binary"
},
function(err,data){ // CALLBACK OF HTTP GET
if(err){
console.log("S3 Error: "+err);
}else{
console.log("S3 Data: "+JSON.stringify(data));
}
}
);
}
});
实际上,我正试图通过HTTP调用使用filepicker.io REST API,即用于将转换后的图像存储到我的s3,但对于这个问题,这是演示实际问题的最低示例。最好的解决方案是查看在这方面已经做了哪些工作: 另外,filepicker.so似乎非常简单:
经过几次试运行后,我放弃了Meteor.HTTP,并将下面的代码放在一起,也许它会在遇到Meteor.HTTP的编码问题时对某些人有所帮助
Meteor.HTTP
似乎只是从远程API获取一些JSON或文本数据,而对于二进制数据的选择似乎并不安静。然而,Npm HTTP模块确实支持二进制数据,因此这很有魅力:
var http=Npm.require("http");
url = "http://www.whatever.com/check.jpg";
var req = http.get(url, function(resp) {
var buf = new Buffer("", "binary");
resp.on('data', function(chunk) {
buf = Buffer.concat([buf, chunk]);
});
resp.on('end', function() {
var thisObject = {
ACL: "public-read",
Bucket: "mybucket",
Key: "myNiceImage.jpg",
Body: buf,
ContentType: resp.headers["content-type"],
ContentLength: buf.length
};
s3.putObject(thisObject, function(err, data) {
if (err) {
console.log("S3 Error: " + err);
} else {
console.log("S3 Data: " + JSON.stringify(data));
}
});
});
});
嘿,FredericoC,谢谢你的输入,这些信息来源确实很好,但没有涉及到这个案例。我会更新我的帖子,让它更清楚,这是一个服务器端的获取和推送,没有客户端参与。