`

JS在浏览器中解析Base64编码图像(转)

 
阅读更多

上一篇介绍中,我们将二进制文件(BLOB)保存为Base64编码的文本,这些文本可以内嵌在XML的标签中,因此二进制信息它可以随着XML文件被拷贝、下载而不用担心信息会缺失。这项技术也在email邮件中被广泛使用。

浏览器对Base64的支持

图像是最经常被使用的一种二进制文件。而现代的浏览器的进步日新月异,IE7,FireFox和其他浏览器为包括Base64在内各种编码的图像信息提供了很好的支持。因此图形信息可以以下面的形式呈现在页面中、

Java代码

1
2
3
4
<img src="data:image/gif;base64,R0lGODlhDwAPAKECAAAAzMzM/////
wAAACwAAAAADwAPAAACIISPeQHsrZ5ModrLlN48CXF8m2iQ3YmmKqVlRtW4ML
wWACH+H09wdGltaXplZCBieSBVbGVhZCBTbWFydFNhdmVyIQAAOw=="
alt="Base64 encoded image" width="150" height="150"/>

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<body>
 <img src="data:image/gif;base64,R0lGODlhDwAPAKECAAAAzMzM///// 
wAAACwAAAAADwAPAAACIISPeQHsrZ5ModrLlN48CXF8m2iQ3YmmKqVlRtW4ML 
wWACH+H09wdGltaXplZCBieSBVbGVhZCBTbWFydFNhdmVyIQAAOw=="
alt="Base64 encoded image" width="150" height="150"/>
</body>
</html>

 

这种data: URI的格式能把Base64(或其他数据)可以内嵌在image标签的属性当中(或者CSS中)。我们可以看到在大部分浏览器中的显示效果: 

这种做法有利有弊,好处是浏览器可以在一个连接中得到完成的页面内容,不好的地方时图像的大小会增加1/3。因此,这种内嵌的方法适合对小的图形元素比如图标、圆角等等进行处理,从而减少浏览器打开的连接数,但对大的照片、图片(量少而大)等等则不应该使用Base64编码以免影响下载速度。

为了得到刚才的Base64编码,我们将上一篇的Java修改成Struts Action,并借用了JIMI进行图形的读取和格式转换,Base64编码器则改为更普遍的Apache Commons组件,代码如下:

Java代码 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public class Base64ImageAction extends ActionSupport {
  private final static String galleryName = "gallery";
 private static String parent = null;
   private String encodeString = null;
 public String getEncodeString() {
  return encodeString;
 }
 public void setEncodeString(String encodeString) {
  this.encodeString = encodeString;
 }
 private String getImageFullPath() {
  parent = new File(this.getClass().getClassLoader().getResource(
     File.separator).getPath()).getParent()+File.separator+"flag.jpg";
 }
 public String execute() {
  ByteArrayOutputStream output = new ByteArrayOutputStream();
  try {
   JimiReader reader = Jimi.createJimiReader(this.getImageFullPath());
   Image image = reader.getImage();
   Jimi.putImage("image/png", image, output);
   output.flush();
   output.close();
   this.encodeString = Base64.encodeBase64String(output.toByteArray());
  } catch (IOException e) {
   e.printStackTrace();
  } catch (JimiException e) {
   e.printStackTrace();
  }
  return SUCCESS;
 }
}

对应的View端是个十分简单的Freemarker模板:

Html代码

1
2
3
4
5
6
7
8
<html>
<head>
<title>Hello,World</title>
</head>
<body>
<img src="data:image/png;base64,${encodeString}" />
</body>
</html>

处理古代浏览器

世界总是不是那么完美,尽管大部分现代浏览器对Base64的处理都十分完善,但是我们不能不考虑到一些“古老”的浏览器,而现在还是普遍使用的“古老”的浏览器,就当属IE6,在IE6里试图浏览上面的图片可能会得到一个红叉叉。我们不得不为IE6做一些特殊处理,利用下面的JavaScript,我们把Base64字串传回服务器端,重新解析成图片

Javascript代码 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// a regular expression to test for Base64 data
var BASE64_DATA = /^data:.*;base64/i;
// path to the PHP module that will decode the encoded data
var base64Path = "/my/path/base64.php";
function fixBase64(img) {
 // check the image source
 if (BASE64_DATA.test(img.src)) {
 // pass the data to the PHP routine
 img.src = base64Path + "?" + img.src.slice(5);
 }
};
// fix images on page load
onload = function() {
 for (var i = 0; i < document.images.length; i++) {
 fixBase64(document.images[i]);
 }
};

服务器端的Struts可以参考上面的例子做反向操作,具体从略。

更完美的方法

将Base64传回服务器解码是不错的IE6补丁,但是违背了我们的初衷,对IE6来说,浏览器连接数并未有任何减少。更直接的想法,是否能用Javascript直接在浏览器中,对Base64文本进行解码呢?我们构思的场景如下:服务器端先将图片转换成PNG格式以方便客户端进行处理,Base64编码之后,利用JSON将文本传递给浏览器客户端进行处理。

我们选择PNG图形格式是因为PNG已经俨然成为新的Web图形标准,它格式非常简单,可以很方便的用javascript进行处理而不需要借助浏览器的支持。我们知道javascript直接不能处理二进制数据,但是现在这不是个问题,服务器端已经准备好了Base64编码的文本数据,现在我们只需要一个javascript的Base64解析器,你可以在这里找到一个notmasteryet的Base64解析器。

现在PNG图形格式采用了DEFLATE作为唯一的压缩算法,该算法也广泛应用在ZIP,GZIP等压缩格式中。PNG图像格式文件(或者称为数据流)由一个8字节的PNG文件署名(PNG file signature)域和按照特定结构组织的3个以上的数据块(chunk)组成。

PNG定义了两种类型的数据块,一种是称为关键数据块(critical chunk),这是标准的数据块,另一种叫做辅助数据块(ancillary chunks),这是可选的数据块。关键数据块定义了4个标准数据块,其中图像数据块IDAT(image data chunk):它存储实际的数据, PNG总的数据流采用DEFLAT进行压缩。此外还擦用三角过滤“delta filters”来过滤每一行的像素的未压缩数据。DEFLAT和delta压缩在其他数据和文本处理中也被广泛应用。PNG格式你可以参考<a href="http://www.libpng.org/pub/png/spec/1.1/PNG-Contents.html">官方文档</a>。

很棒的,notmasteryet也为我们提供了一个DEFLAT解压器。

最后,我们把这些组合起来:

Html代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<head>
 <title>Demo JavaScript PNG Viewer</title>
 </head>
<body onload="show(gravatar);">
<script src="../Source/Base64.js" type="text/javascript"></script>
<script src="../Source/Deflate.js" type="text/javascript"></script>
<script src="../Source/PNG.js" type="text/javascript"></script>
<script type="text/javascript">
var gravatar = 'iVBORw0KGgoAAAANSUhEUgAAA.......数据从略......55CYII=';
String.prototype.padRight = function(c, n){
 var txt = '';
 for(var i=0;i<n-this.length;i++) txt += c;
 return txt + this;
};
function show(data){
 var png = new PNG(data);
 var img = document.getElementById('image'), limg = document.getElementById('largeimage');
 document.getElementById('nativeimage').src = 'data:image/png;base64,' + data;
 img.innerHTML = '';
 limg.innerHTML = '';
 img.style.width = png.width + 'px';
 img.style.height = png.height + 'px';
 limg.style.width = (png.width * 3) + 'px';
 limg.style.width = (png.height * 3) + 'px';
 var line;
 while(line = png.readLine())
 {
  for (var x = 0; x < line.length; x++){
   var px = document.createElement('div'), px2 = document.createElement('div');
   px.className = px2.className = 'pixel';
   px.style.backgroundColor = px2.style.backgroundColor = '#' + line[x].toString(16).padRight('0', 6);
   img.appendChild(px);
   limg.appendChild(px2);
  }
 }
}
</script>
<div id="image"></div>
<div id="largeimage"></div>
<img id="nativeimage" />
</body>
</html>

以上所述是小编给大家介绍的JS在浏览器中解析Base64编码图像,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

原文链接:http://blog.csdn.net/elf8848/article/details/39927385

分享到:
评论

相关推荐

    JS在浏览器中解析Base64编码图像

    JS在浏览器中解析Base64编码图像,指的是使用JavaScript在网页中嵌入和显示Base64编码的图像。 在浏览器中,图像可以通过data:URI模式嵌入到HTML中,这是一种MIME类型,允许直接在MIME头部中包含数据。Data:URI的...

    js 显示base64编码的二进制流网页图片

    而在JavaScript中,可以使用btoa()函数对字符串进行Base64编码,以及atob()函数对Base64编码的字符串进行解码。 关于浏览器对Base64编码数据的支持,当前主流浏览器如IE8、Firefox、Chrome和Opera等都已经支持Data ...

    图片在线转Base64编码 v1.0.rar

    5. **在线工具**:由于描述中提到的是“在线转”,这意味着这个工具可能是一个Web应用程序,用户可以在浏览器中直接上传图片并获取Base64编码结果,无需下载和安装额外的软件。 6. **信息管理**:在Web开发中,信息...

    Base64_javascript_base64_

    在JavaScript中,Base64的加密与解密是前端开发中的常见需求,尤其在处理图像、JSON数据或者进行跨域通信时。本文将深入探讨JavaScript中的Base64原理及其在前端应用。 一、Base64编码原理 Base64编码将每3个8位...

    H5移动端Base64压缩图片

    base64,`,表示这是JPEG格式的Base64编码图像。最后,我们创建了一个隐藏的下载链接,将Base64字符串设为其`href`属性,并模拟点击事件触发下载。 需要注意的是,由于Base64编码后的字符串比原始图片文件大,因此...

    base64js文件

    5. **兼容性**: JavaScript运行在各种不同的环境中,`base64js`库可能会考虑浏览器兼容性问题,确保在旧版本的浏览器中也能正常工作。 6. **API设计**: `base64js`可能提供了一套简洁的API,使得开发者能够轻松地在...

    HTML5HTML5 选图 压缩 base64编码 上传 解码

    在JavaScript中,我们可以创建FormData对象,将base64编码的图片转换回Blob,然后添加到FormData中。例如: ```javascript let formData = new FormData(); formData.append('image', b64toBlob(base64String), '...

    js对图片base64编码字符串进行解码并输出图像示例

    标题“js对图片base64编码字符串进行解码并输出图像示例”和描述“主要介绍了js对图片base64编码字符串进行解码并输出图像的具体实现,大家可以参考下面的示例”揭示了文章的核心内容是关于在JavaScript中将图片的...

    图片互转Base64

    在IT领域,Base64是一种数据编码方法,常用于在电子邮件系统、网页和其他需要传输二进制数据的环境中转换文本格式。"图片互转Base64"是指将图片文件转换成Base64字符串,同时也能够将Base64字符串还原为图片文件。...

    base64,java与JavaScript实现

    ### 关于Base64编码及Java与JavaScript的实现 #### Base64简介 Base64是一种将二进制数据转换为ASCII字符串表示形式的方法。它主要用于处理非文本数据的存储和传输,例如图像、视频等多媒体文件。由于互联网传输...

    Base64图片转换

    在前端,我们可以通过创建一个新的`&lt;img&gt;`标签,将其`src`属性设置为Base64编码的data URL,这样浏览器就会解析这个编码并显示图片。例如: ```html &lt;img id="myImage" src="" alt="Base64 Image"&gt; ``` ```...

    根据DOM将html转为canvas图片格式

    在Web中,Base64编码常用于在URL中传递图片数据,或者在CSS、JavaScript等文本格式中嵌入图像。将Canvas转换为base64编码的图片,可以方便地在浏览器中显示或通过网络传输。 5. 兼容性问题: 描述中提到,这个功能...

    js转换图片到Excel 里面

    用户可以通过HTML的`&lt;input type="file"&gt;`元素选择图片,然后通过`FileReader`的`readAsDataURL`方法将图片转换为Base64编码的字符串,这是一种可以在浏览器环境中直接使用的数据格式。 2. Base64编码:Base64是一...

    Node.js-从浏览器接收canvas帧并在服务器上生成视频与CCapture.js兼容

    **Node.js 从浏览器接收canvas帧并在服务器生成视频** 在现代Web开发中,HTML5的Canvas元素被广泛用于创建动态图形和交互式内容。而有时,我们可能希望将这些动态生成的帧保存为视频文件,以便离线查看或进一步处理...

    phantomjs工具

    在ECharts的场景中,PhantomJS可以用来生成基于Base64编码的图表,这对于网页开发、数据可视化和无头浏览器操作等具有重要意义。 ECharts是百度开源的一款轻量级、高性能的JavaScript图表库,它提供了丰富的图表...

    图像预览控件

    然而,由于IE8的限制,当Base64编码的字符串长度超过一定阈值时,浏览器无法正确解析并显示图像,这无疑给开发者带来了困扰。 为了解决这个问题,我们可以开发一个特定的“图像预览控件”。这个控件的核心功能是将...

    Javascript将图片的绝对路径转换为base64编码的方法

    在JavaScript中,将图片的绝对路径转换为Base64编码主要涉及到HTML5的Canvas API以及数据URL的概念。Base64编码是一种将二进制数据转化为可打印字符的表示方式,常用于在网络上传输图片或者在CSS中嵌入图片。在这个...

    div转png/jpg格式图片,兼容IE9+及主流浏览器

    在给定的“div转图片”主题中,我们主要探讨的是如何在IE9+以及主流浏览器中使用canvas2image、html2canvas和base64技术实现这个功能。 首先,`html2canvas`是一个JavaScript库,它允许我们在浏览器环境中将HTML...

    Base64 URL-crx插件

    通过在浏览器的搜索框中输入“b64”后接一个Base64编码的URL,用户可以直接打开并浏览该编码后的网址所对应的网页,无需先解码再访问,极大地提高了工作效率。 在技术层面上,Base64编码是基于64个可打印字符的编码...

    image-to-base64-or-buffer:压缩图像(jpg,png),然后将其编码为base64

    在Web开发中,Base64编码常用于在页面上内联显示图片,因为浏览器可以理解并解析这种编码格式。在`image-to-base64-or-buffer`库中,图像被编码为Base64字符串,可以直接嵌入到HTML的`&lt;img&gt;`标签的`src`属性中,或者...

Global site tag (gtag.js) - Google Analytics