我做了一个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.)
答案 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”部分