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