0

我正在尝试使用 request.js 将文件上传到 s3,但上传后文件数据似乎不正确。我应该改用响应对象的数据属性吗?

        var flickrPhotoUrl = 'http://c1.staticflickr.com/3/2207/2305523141_1f98981685_z.jpg?zz=1';

        request.get(flickrPhotoUrl, function(error, response, body){

            if (body) {
                s3.upload({
                    Body: body,
                    Bucket: 'my-uploads',
                    Key: 'photo.jpg',
                }, function (err) {
                    done(err);
                });
            }
            else
            {
                done('no response');
            }
        });

当我在上传后从 s3 抓取文件时,它不是一个可识别的图像,而且似乎是原来的两倍。

4

1 回答 1

1

request默认情况下将您的图像二进制数据转换为 utf8 字符串。这就是文件大小大于实际大小的原因。尝试传递encoding:null以保留bodyas 缓冲区:

request.get({encoding:null, uri: flickrPhotoUrl}, function(error, response, body){ 
  ...
})

更新: 我认为您也可以在Body参数中传递一个可读流。对于大文件,这比上面的要快。

var stream = request.get(flickrPhotoUrl)
s3.upload({
    Body: stream,
    Bucket: 'my-uploads',
    Key: 'photo.jpg',
}
于 2015-08-05T00:47:52.057 回答