简体   繁体   English

将 base64 编码的图像上传到 Node.js 服务器不起作用

[英]Uploading a base64 encoded image to Node.js server not working

I'm using MEAN.io and i'm trying to upload a base64 encoded image.我正在使用 MEAN.io 并且我正在尝试上传 base64 编码的图像。

Client side, AngularJS:客户端,AngularJS:

          // Image we're going to send it out
          var base64Image = files[i];

          var file = {
            image: base64Image,
            type: type,
            filetype: extension,
            characterId: character._id
          };

          var newFile = new MediaSendBase64(file);

          newFile.$save(function(image) {
            if ( !image ) {
              console.log('ERROR IMAGE');
            }
            else {
              console.log('SUCCESS.');

              console.log(image);
            }
          });

Server side, NodeJS, controller:服务器端、NodeJS、控制器:

app.use(bodyParser.json({limit: '50mb'}));
app.use(bodyParser.urlencoded({limit: '50mb', extended: true}));

exports.uploadBase64 = function(req, res, next) {

  var uploadPath  = path.normalize(process.cwd() + '/packages/characters/public/assets/uploads/'),
      data        = new Buffer(''),
      imgURL      = undefined,        // public URL to show the pic
      type        = undefined;


  // In case the '/uploads' directoy doesn't exist
  if( !fs.existsSync(uploadPath) ) {
    fs.mkdirSync(uploadPath, 0755);
  }


  // Decoding the base64 image
  var data = new Buffer(req.body.image, 'base64');

  // Creating the name for the file --> characterId + type + timestamp + extension
  var filename = req.body.characterId + '-' + req.body.type + '-' + new Date().getTime().toString() + '.' + req.body.filetype;

  // Writing the image to filesystem
  fs.writeFile(uploadPath + filename, data, function (err) {

    if ( err ) {
      console.log(err);
      return res.status(500).json({
        error: 'Cannot upload the image. Sorry.'
      });
    }

    console.log('SAVED ON HD');

    console.log('FINISHING');

    // Sending success response
    res.json({
      imgURL: imgURL,
      type: type
    });

  });

};

The thing is the file stored in /uploads isn't work.问题是存储在 /uploads 中的文件不起作用。 I can't see the image.我看不到图像。 The base64 image is sent and the file is written to hard disk, but it is not possible to open it.发送base64图像并将文件写入硬盘,但无法打开它。

What's wrong?怎么了? Any suggestion?有什么建议吗?

Thanks!谢谢!

It maybe that you are trying to save the file with the metadata.您可能正在尝试使用元数据保存文件。 hence making the decoded data from base64 invalid.因此使来自 base64 的解码数据无效。

Here is what I mean:这就是我的意思:

....

The data:image/png;base64 is just meta and is not encoded using base64 so: data:image/png;base64 只是元数据,不是使用 base64 编码的,所以:

You need to strip that from the sting then decode then save to disk.您需要将其从刺中剥离,然后解码,然后保存到磁盘。

I use this handy function:我使用这个方便的功能:

function decodeBase64Image(dataString) {
  var matches = dataString.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/),
    response = {};

  if (matches.length !== 3) {
    return new Error('Invalid input string');
  }

  response.type = matches[1];
  response.data = new Buffer(matches[2], 'base64');

  return response;
}

source: NodeJS write base64 image-file来源: NodeJS 编写的 base64 图像文件

So a snip from how I use it:所以从我如何使用它的片段:

 var decodedImg = decodeBase64Image(imgB64Data);
 var imageBuffer = decodedImg.data;
 var type = decodedImg.type;
 var extension = mime.extension(type);
 var fileName =  "image." + extension;
 try{
       fs.writeFileSync(".tmp/uploads/" + fileName, imageBuffer, 'utf8');
    }
 catch(err){
    console.error(err)
 }

Where mime is the great node-mime lib.其中 mime 是伟大的 node-mime 库。 npm install mime. npm 安装 mime。

if your using express file upload you could do this如果您使用快速文件上传,您可以这样做

routerApi.patch('/upload_gambar', (req, res) => {
    var file_data= req.files.upload_file_name.data;
    var base64Image = file_data.toString('base64');
}

if your using multer file upload you could do this如果您使用 multer 文件上传,您可以执行此操作

routerApi.patch('/upload_gambar', upload.single('upload_file_name'),(req, res) => {
    var file_data= req.file.buffer
    var base64Image = file_data.toString('base64');
}

Node js base64 to image convert and upload on disk after read and write here code working with me. Node js base64 在与我一起阅读和编写此处的代码后,将图像转换并上传到磁盘上。

var imgBase64 = '';

var base64Data = imgBase64.replace(/^data:image\/png;base64,/, "");
    fs.writeFile(uploadPath+"/out.png", base64Data, 'base64', function(err) {
    console.log(err);
    });
fs.readFileSync(base64Data, {encoding: 'base64'});

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM