Safari中的Base64图像标签没有显示出来

时间:2014-12-10 08:32:02

标签: html5 image safari base64

我做了一个tsp,它将Image解码为base64字节数组String。

适用于Chrome和Firefox。但是在Safari 8.0中,它不起作用。

我的jsp如下所示:

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();
}

结果以下代码将附加到浏览器。

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

我复制此代码(base64;之后的一部分)并将下面的链接放在safari中。

http://base64online.org/decode/

我得到了一张图片,所以我认为Safari也支持base64图片。

但是,当我把它放在带有图片标签的网页上时,它不起作用。

感谢您的回答:D

PS浏览器错误消息

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

3 个答案:

答案 0 :(得分:7)

我知道这个问题已经很久了,但我最近在iOS上遇到了类似的问题。 safari,问题似乎是Safari不会渲染base64图像,这些图像没有可被4整除的字符数。

此问题的解决方案是使用&#39; =&#39;来填充末尾的编码字符串。字符。这是一个基本算法:

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

希望这有助于某人!

答案 1 :(得分:5)

我处于类似的情况,但发布的解决方案对我不起作用。但经过一些试验和错误后,我确实提出了另一种解决方案。希望这会有所帮助。

// 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);

答案 2 :(得分:0)

@SylvainB-我认为它需要被3或4整除才能在Safari中呈现 @IHan-在进行除数测试时,请确保排除“ data:image / png; base64”部分