Encoding Meteor:将图像从URL保存到AWS S3存储

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

我正在尝试,服务器端,通过它的url(即)从web上获取图像,并使用Meteor、AWS sdk meteorite包以及http Meteor包将此图像保存到我的AWS S3存储桶中

这是我的尝试,它确实将一个文件放入我的bucket(someImageFile.jpg),但该图像文件随后已损坏,无法由浏览器或查看器应用程序显示

可能我对文件的编码有问题。我尝试了许多组合,但都不起作用。此外,我还尝试使用不同的编码添加ContentLength和/或ContentEncoding,如binary、hex、base64(也与
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,谢谢你的输入,这些信息来源确实很好,但没有涉及到这个案例。我会更新我的帖子,让它更清楚,这是一个服务器端的获取和推送,没有客户端参与。