从url下载文件并将其上传到AWS S3而不保存 – node.js

我正在编写一个应用程序,它从url下载图像,然后使用aws-sdk将其上传到S3存储桶。

很明显,我只是下载图像,并像这样保存到磁盘。

request.head(url, function(err, res, body){ request(url).pipe(fs.createWriteStream(image_path)); }); 

然后像这样将图像上传到AWS S3

 fs.readFile(image_path, function(err, data){ s3.client.putObject({ Bucket: 'myBucket', Key: image_path, Body: data ACL:'public-read' }, function(err, resp) { if(err){ console.log("error in s3 put object cb"); } else { console.log(resp); console.log("successfully added image to s3"); } }); }); 

但我想跳过保存图像到磁盘的部分。 有什么办法可以将request(url)的响应传递给一个variables,然后上传?

       

网上收集的解决方案 "从url下载文件并将其上传到AWS S3而不保存 – node.js"

这里有一些很好的javascript:

  var options = { uri: uri, encoding: null }; request(options, function(error, response, body) { if (error || response.statusCode !== 200) { console.log("failed to get image"); console.log(error); } else { s3.putObject({ Body: body, Key: path, Bucket: 'bucket_name' }, function(error, data) { if (error) { console.log("error downloading image to s3"); } else { console.log("success uploading to s3"); } }); } });