4

I'm using JavaScript to get an image from the XMLHttpRequest response text and set the image src to it:

document.getElementById("img").src = "data:image/png;base64," +  xhr.responseText;

From the nodejs script, the image is sent like:

var img = fs.readFileSync('image.png');
res.end(img, 'base64');

The response text doesn't come in base64 and has weird symbols:

�PNG���IHDR���������,���2PLTE �������������������������@����Ai���

...

I found this question and tried to convert it to base 64:

for (var responseText = xhr.responseText, responseTextLen = responseText.length, bin = "", i = 0; i < responseTextLen; ++i) {
    bin += String.fromCharCode(responseText.charCodeAt(i) & 255);
}
document.getElementById("img").src = "data:image/png;base64," + btoa(bin);

The result was:

img id="img" src="">

The image still doesn't show. What am I doing wrong?

Community
  • 1
  • 1
badjr
  • 2,166
  • 3
  • 20
  • 31
  • have you considered to send the image directly and read it as a `blob` from the browser? [this](http://stackoverflow.com/questions/17657184/using-jquerys-ajax-method-to-retrieve-images-as-a-blob) post for reference –  Aug 14 '15 at 07:59
  • 1
    You need to do the base64 encoding on the server side, not the client side. I'd say that `res.end(img, 'base64');` doesn't do what you think it does - ie, its *not* base64 encoding `img`. – Dal Hundal Aug 14 '15 at 08:09

2 Answers2

1

It sounds like you're looking for buf.toString([encoding][, start][, end]).

Consider the following code:

var fs = require('fs');
var base64_image = fs.readFileSync('image.png').toString('base64');

console.log(base64_image);

This will return image.png as a base64 encoded string in the console.

So you probably want to remove that for () loop and change:

var img = fs.readFileSync('image.png');

To this:

var img = fs.readFileSync('image.png').toString('base64');

I hope that helps!

Coffee'd Up Hacker
  • 1,356
  • 11
  • 23
0

As Dal suggested, I did the base64 encoding on the server side:

var img = fs.readFileSync('plot.png', 'base64');
res.end(img);

I added the 'base64' encoding option to the readFileSync() instead of the res.end() so img would get sent as a string instead of a buffer as described here.

On the client side, I used this:

document.getElementById("img").src = "data:image/png;base64," + xhr.responseText;
badjr
  • 2,166
  • 3
  • 20
  • 31