Convert Base64 image to raw binary with Node.js

remotevision picture remotevision · Sep 25, 2013 · Viewed 18.1k times · Source

I have found posts that are close to what I'm looking for, but I have not been able to successfully implement what I want. Here is the general flow:

  1. Submit photo with rest of venue data, as base64 data
  2. Strip data prefix if it exists, so I have just the image base64 data

var base64data = venue.image.replace(/^data:image\/png;base64,|^data:image\/jpeg;base64,|^data:image\/jpg;base64,|^data:image\/bmp;base64,/, '');

  1. Store Base64 data in GridFS via MongoDB (I'm using gridfstore)
  2. Then, I'd like to retrieve the image upon request as a raw image file via a URL.

// generic images route
server.get(version+'/images/:id', function(req, res) {
  gridfstore.read( req.params.id, function(error,data) {
    res.writeHead(200, {
      'Content-Type': 'image/jpeg',
      'Content-Length': data.buffer.length
    });

    res.end(data.buffer);
  });
});

Basically, this method returns the Base64 bytes stored in GridFS. I have tried other methods but they don't return the raw image.

I'd like to pull up the image using URLs like this:

http://[localhost]/1/images/11dbcef0-257b-11e3-97d7-cbbea10abbcb

Here is a screenshot of the browser trace: browser trace

Answer

hexacyanide picture hexacyanide · Sep 25, 2013

You can take the string from MongoDB, create a new buffer instance, and specify an encoding when doing so. The resultant buffer will be in binary data.

var b64str = /* whatever you fetched from the database */;
var buf = new Buffer(b64str, 'base64');

So in your implementation:

server.get(version+'/images/:id', function(req, res) {
  gridfstore.read(req.params.id, function(err, data) {
    var img = new Buffer(data.buffer, 'base64');

    res.writeHead(200, {
      'Content-Type': 'image/jpeg',
      'Content-Length': img.length
    });
    res.end(img); 

  });
});