html5中文学习网

您的位置: 首页 > 网络编程 > java教程 » 正文

Java 8实现图片BASE64编解码_java_

[ ] 已经帮助:人解决问题

前言n8HHTML5中文学习网 - HTML5先行者学习网

Basic编码是标准的BASE64编码,用于处理常规的需求:输出的内容不添加换行符,而且输出的内容由字母加数字组成。n8HHTML5中文学习网 - HTML5先行者学习网

最近做了个Web模版,其中想用Base64背景图。虽然网络上有现成的编码器,但总想自己实现一个。可能很多人不知道,JDK 8新提供的Base64类可以非常方便地处理此项任务:Base64 (Java Platform SE 8 ) n8HHTML5中文学习网 - HTML5先行者学习网

一、先选一张图片n8HHTML5中文学习网 - HTML5先行者学习网

mm.pngn8HHTML5中文学习网 - HTML5先行者学习网

n8HHTML5中文学习网 - HTML5先行者学习网

二、建立HTML演示文件模版n8HHTML5中文学习网 - HTML5先行者学习网

test.htmln8HHTML5中文学习网 - HTML5先行者学习网

<!DOCTYPE html><html><head lang="zh-CN"> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width"> <title>测试Base64编码 - 2gua</title> <style type="text/css">  #thisImage {   margin: 20px auto;   -webkit-border-radius: 50%;   border-radius: 50%;   background: url() no-repeat center center;   background-size: contain;   border: 8px solid #EDEDED;   width: 128px;   height: 128px;  } </style></head><body> <div id="thisImage"></div></body></html>

注意url()为空,稍后我们要把生成的Base64编码字符串植入其中。n8HHTML5中文学习网 - HTML5先行者学习网

三、编写Java程序n8HHTML5中文学习网 - HTML5先行者学习网

这里将实现Base64编解码的双向实现,尽管本例中只需要用到Base64解码。Java程序的注释很清楚了,直接上代码:n8HHTML5中文学习网 - HTML5先行者学习网

`Base64Trans.java`package com.gua;/** * Created by 2gua on 2014/10/5. */import java.io.IOException;import java.nio.file.*;import java.util.Base64;import static java.lang.System.out;public class Base64Trans { /**  * 从图片文件中读取内容。  * @param path 图片文件的路径。  * @return 二进制图片内容的byte数组。  *  */ private byte[] readFile(Path path) {  byte[] imageContents = null;  try {   imageContents = Files.readAllBytes(path);  } catch (IOException e) {   out.println("读取文件出错了...~zZ");  }  return imageContents; } /**  * 编码图片文件,编码内容输出为{@code String}格式。  * @param imageContents 二进制图片内容的byte数组。  * @return {@code String}格式的编码内容。  */ private String base64Encoding(byte[] imageContents) {  if(imageContents != null)   return Base64.getEncoder().encodeToString(imageContents);  else return null; } /**  * 解码图片文件。  * @param imageContents 待解码的图片文件的字符串格式。  * @return 解码后图片文件的二进制内容。  */ private byte[] base64Decoding(String imageContents) {  if(imageContents != null)   return Base64.getDecoder().decode(imageContents);  else return null; } /**  * 将解码后的二进制内容写入文件中。  * @param path 写入的路径。  * @param imageContents 解码后的二进制内容。  */ private void writeFile(Path path, byte[] imageContents) {  if(imageContents != null)   try {    Files.write(path, imageContents, StandardOpenOption.CREATE);   } catch (IOException e) {    out.println("写入文件出错了...~zZ");   } } public static void main(String[] args) {  Base64Trans bt = new Base64Trans();  String encodingString = bt.base64Encoding(bt.readFile(Paths.get("D:/temp/mm.png")));  out.println("二进制图片文件Base64码:" + encodingString);  bt.writeFile(Paths.get("D:/temp/mm2.png"), bt.base64Decoding(encodingString));  out.println("任务结束..."); }}

程序结果如下:n8HHTML5中文学习网 - HTML5先行者学习网

二进制图片文件Base64码:iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB...(此处省略n多字符)8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==任务结束...

四、最后设置n8HHTML5中文学习网 - HTML5先行者学习网

要在HTML文件模版test.html中引用Base64编码内容,还有一步工作要做:将以下内容加到Base64编码内容的开头处:data:image/png;base64,n8HHTML5中文学习网 - HTML5先行者学习网

最终结果也就是类似这样:n8HHTML5中文学习网 - HTML5先行者学习网

data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB...(此处省略n多字符)8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==

之后,将这一长串字符串植入以下代码行的url()括号中:n8HHTML5中文学习网 - HTML5先行者学习网

background: url() no-repeat center center;

如果图片是JPG格式,请将上面data:image/png;base64中的png改为jpeg,如果是GIF格式就改为gif。好了,刷新页面,看看结果:n8HHTML5中文学习网 - HTML5先行者学习网

n8HHTML5中文学习网 - HTML5先行者学习网

有圆圈圈是因为我们设置了一些CSS3特效。n8HHTML5中文学习网 - HTML5先行者学习网

我们还实现了Base64解码,并生成一个新的mm2.png图片,在图片浏览器中打开mm2.png,效果应该跟mm.png是一模一样的。n8HHTML5中文学习网 - HTML5先行者学习网

其实,每次JDK新版发布,都蕴藏着许多大大小小的更新,只是你是否有意去发掘它而已。Java总是那么健壮和让人放心。n8HHTML5中文学习网 - HTML5先行者学习网

总结n8HHTML5中文学习网 - HTML5先行者学习网

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。n8HHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助