Base64 tag did not appear in safari

I made a tsp that decodes Image to base64 String byte array.

It works in Chrome and Firefox. However, in Safari 8.0 it doesn't work.

My jsp looks like this:

String sFileInfo = "";
String name = request.getHeader("file-name");
String ext = name.substring(name.lastIndexOf(".")+1);

InputStream is = request.getInputStream();
byte b[] = IOUtils.toByteArray(is);

String base64DataString = Base64.encodeBase64String(b);

base64DataString = "data:image/" + ext + ";base64," + base64DataString;

if(is != null) {
  is.close();
}

      

And as a result, the code below will be attached to the browser.

<p><span style="font-size:48px"><img alt="" src="" style="height:90px; width:169px" />1<span style="background-color:#00FFFF">zxczxczc</span></span></p>

      

I copy this code (part after base64;

) and put the link below in safari.

http://base64online.org/decode/

and I got the image, so I assume Safari also supports base64 image.

However, when I put this on the internet with image tags, it doesn't work.

Thanks for the answer: D

PS Browser Error Message

Failed to load resource: (kCFErrorDomainCFNetwork error -10.)

+3


source to share


2 answers


I was in a similar situation, but the posted solution did not work for me. But after some trial and error, I came up with an alternative solution. Hope this helps.



// Add an actual base64 string
var encodedImgString = '...';

// Create an image, set img source and cross origin attribute
var isoImg = new Image;
iosImg.src = encodedImgString;
iosImg.crossOrigin = 'Anonymous';

// Change this to target your element and add it wherever you need it to appear
document.body.appendChild(iosImg);

      

+5


source


I know this question is pretty old, but I recently ran into a similar issue on iOS safari and the problem is that Safari won't display base64 images that don't have a divisible by 4 character count.

The solution to this problem is to fill your encoded string at the end with '=' characters. Here's the basic algorithm:



// b64str = 's/3eea4sp...' (or any base 64 encoded string)
while (b64str.length % 4 > 0) {
    b64str += '=';
}

      

Hope this helps someone!

+6


source







All Articles