前言
Basic編碼是標(biāo)準(zhǔn)的BASE64編碼,用于處理常規(guī)的需求:輸出的內(nèi)容不添加換行符,而且輸出的內(nèi)容由字母加數(shù)字組成。
最近做了個(gè)Web模版,其中想用Base64背景圖。雖然網(wǎng)絡(luò)上有現(xiàn)成的編碼器,但總想自己實(shí)現(xiàn)一個(gè)??赡芎芏嗳瞬恢溃琂DK 8新提供的Base64類可以非常方便地處理此項(xiàng)任務(wù):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 >測(cè)試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編碼字符串植入其中。
三、編寫(xiě)Java程序
這里將實(shí)現(xiàn)Base64編解碼的雙向?qū)崿F(xiàn),盡管本例中只需要用到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 { /** * 從圖片文件中讀取內(nèi)容。 * @param path 圖片文件的路徑。 * @return 二進(jìn)制圖片內(nèi)容的byte數(shù)組。 * */ private byte [] readFile(Path path) { byte [] imageContents = null ; try { imageContents = Files.readAllBytes(path); } catch (IOException e) { out.println( "讀取文件出錯(cuò)了...~zZ" ); } return imageContents; } /** * 編碼圖片文件,編碼內(nèi)容輸出為{@code String}格式。 * @param imageContents 二進(jìn)制圖片內(nèi)容的byte數(shù)組。 * @return {@code String}格式的編碼內(nèi)容。 */ private String base64Encoding( byte [] imageContents) { if (imageContents != null ) return Base64.getEncoder().encodeToString(imageContents); else return null ; } /** * 解碼圖片文件。 * @param imageContents 待解碼的圖片文件的字符串格式。 * @return 解碼后圖片文件的二進(jìn)制內(nèi)容。 */ private byte [] base64Decoding(String imageContents) { if (imageContents != null ) return Base64.getDecoder().decode(imageContents); else return null ; } /** * 將解碼后的二進(jìn)制內(nèi)容寫(xiě)入文件中。 * @param path 寫(xiě)入的路徑。 * @param imageContents 解碼后的二進(jìn)制內(nèi)容。 */ private void writeFile(Path path, byte [] imageContents) { if (imageContents != null ) try { Files.write(path, imageContents, StandardOpenOption.CREATE); } catch (IOException e) { out.println( "寫(xiě)入文件出錯(cuò)了...~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( "二進(jìn)制圖片文件Base64碼:" + encodingString); bt.writeFile(Paths.get( "D:/temp/mm2.png" ), bt.base64Decoding(encodingString)); out.println( "任務(wù)結(jié)束..." ); } } |
程序結(jié)果如下:
1
2
3
4
|
二進(jìn)制圖片文件Base64碼:iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB ...(此處省略n多字符) 8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg== 任務(wù)結(jié)束... |
四、最后設(shè)置
要在HTML文件模版test.html中引用Base64編碼內(nèi)容,還有一步工作要做:將以下內(nèi)容加到Base64編碼內(nèi)容的開(kāi)頭處:data:image/png;base64,
最終結(jié)果也就是類似這樣:
1
2
3
|
 ...(此處省略n多字符) 8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg== |
之后,將這一長(zhǎng)串字符串植入以下代碼行的url()
括號(hào)中:
1
|
background: url() no-repeat center center; |
如果圖片是JPG格式,請(qǐng)將上面data:image/png;base64
中的png改為jpeg,如果是GIF格式就改為gif。好了,刷新頁(yè)面,看看結(jié)果:
有圓圈圈是因?yàn)槲覀冊(cè)O(shè)置了一些CSS3特效。
我們還實(shí)現(xiàn)了Base64解碼,并生成一個(gè)新的mm2.png圖片,在圖片瀏覽器中打開(kāi)mm2.png,效果應(yīng)該跟mm.png是一模一樣的。
其實(shí),每次JDK新版發(fā)布,都蘊(yùn)藏著許多大大小小的更新,只是你是否有意去發(fā)掘它而已。Java總是那么健壯和讓人放心。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。