使用request.get文件正文不正确

时间:2015-08-04 22:53:29

标签: node.js requestjs

我正在尝试使用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抓取文件时,它不是一个可识别的图像,似乎是两倍大。

1 个答案:

答案 0 :(得分:1)

默认情况下,

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

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',
}