前言
Basic编码是标准的BASE64编码,用于处理常规的需求:输出的内容不添加换行符,而且输出的内容由字母加数字组成。
最近做了个Web模版,其中想用Base64背景图。虽然网络上有现成的编码器,但总想自己实现一个。可能很多人不知道,JDK 8新提供的Base64类可以非常方便地处理此项任务:Base64 (Java Platform SE 8 ) 。
一、先选一张图片
mm.png
二、建立HTML演示文件模版
test.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
|
<!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编码字符串植入其中。
三、编写Java程序
这里将实现Base64编解码的双向实现,尽管本例中只需要用到Base64解码。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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
`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( "任务结束..." );
}
}
|
程序结果如下:
1
2
3
4
|
二进制图片文件Base64码:iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB
...(此处省略n多字符)
8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==
任务结束...
|
四、最后设置
要在HTML文件模版test.html中引用Base64编码内容,还有一步工作要做:将以下内容加到Base64编码内容的开头处:data:image/png;base64,
最终结果也就是类似这样:
1
2
3
|
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB
...(此处省略n多字符)
8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==
|
之后,将这一长串字符串植入以下代码行的url()
括号中:
1
|
background: url() no-repeat center center;
|
如果图片是JPG格式,请将上面data:image/png;base64
中的png改为jpeg,如果是GIF格式就改为gif。好了,刷新页面,看看结果:
有圆圈圈是因为我们设置了一些CSS3特效。
我们还实现了Base64解码,并生成一个新的mm2.png图片,在图片浏览器中打开mm2.png,效果应该跟mm.png是一模一样的。
其实,每次JDK新版发布,都蕴藏着许多大大小小的更新,只是你是否有意去发掘它而已。Java总是那么健壮和让人放心。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。