通过 Node.js 将 base64 编码的图像上传到 Amazon S3

新手上路,请多包涵

昨天我做了一个深夜编码会议并创建了一个小的 node.js/JS(实际上是 CoffeeScript,但 CoffeeScript 只是 JavaScript,所以可以说是 JS)应用程序。

目标是什么:

  1. 客户端向服务器发送画布数据 (png)(通过 socket.io)
  2. 服务器将图像上传到 amazon s3

步骤 1 完成。

服务器现在有一个字符串 a la

 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAMgAAADICAYAAACt...

我的问题是: 我接下来要将这些数据“流式传输”/上传到 Amazon S3 并在那里创建实际图像的步骤是什么?

knox https://github.com/LearnBoost/knox 似乎是一个很棒的库,可以将某些内容放入 S3, 但我缺少的是 base64-encoded-image-string 和实际上传操作之间的粘合剂

欢迎任何想法、建议和反馈。

原文由 Franz Enzenhofer 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 856
2 个回答

对于仍在为这个问题苦苦挣扎的人。这是我使用原生 aws-sdk 的方法

 var AWS = require('aws-sdk');
AWS.config.loadFromPath('./s3_config.json');
var s3Bucket = new AWS.S3( { params: {Bucket: 'myBucket'} } );

在您的路由器方法中( ContentType 应设置为图像文件的内容类型):

   var buf = Buffer.from(req.body.imageBinary.replace(/^data:image\/\w+;base64,/, ""),'base64')
  var data = {
    Key: req.body.userId,
    Body: buf,
    ContentEncoding: 'base64',
    ContentType: 'image/jpeg'
  };
  s3Bucket.putObject(data, function(err, data){
      if (err) {
        console.log(err);
        console.log('Error uploading data: ', data);
      } else {
        console.log('successfully uploaded the image!');
      }
  });

s3_config.json 文件

 {
  "accessKeyId":"xxxxxxxxxxxxxxxx",
  "secretAccessKey":"xxxxxxxxxxxxxx",
  "region":"us-east-1"
}

原文由 Divyanshu Das 发布,翻译遵循 CC BY-SA 4.0 许可协议

这是我遇到的一篇文章中的代码,发布在下面:

 const imageUpload = async (base64) => {

  const AWS = require('aws-sdk');

  const { ACCESS_KEY_ID, SECRET_ACCESS_KEY, AWS_REGION, S3_BUCKET } = process.env;

  AWS.config.setPromisesDependency(require('bluebird'));
  AWS.config.update({ accessKeyId: ACCESS_KEY_ID, secretAccessKey: SECRET_ACCESS_KEY, region: AWS_REGION });

  const s3 = new AWS.S3();

  const base64Data = new Buffer.from(base64.replace(/^data:image\/\w+;base64,/, ""), 'base64');

  const type = base64.split(';')[0].split('/')[1];

  const userId = 1;

  const params = {
    Bucket: S3_BUCKET,
    Key: `${userId}.${type}`, // type is not required
    Body: base64Data,
    ACL: 'public-read',
    ContentEncoding: 'base64', // required
    ContentType: `image/${type}` // required. Notice the back ticks
  }

  let location = '';
  let key = '';
  try {
    const { Location, Key } = await s3.upload(params).promise();
    location = Location;
    key = Key;
  } catch (error) {
  }

  console.log(location, key);

  return location;

}

module.exports = imageUpload;

阅读更多: http ://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/S3.html#upload-property

致谢: https ://medium.com/@mayneweb/upload-a-base64-image-data-from-nodejs-to-aws-s3-bucket-6c1bd945420f

原文由 Harshal Yeole 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题