前言
Basic編碼是標準的BASE64編碼,用於處理常規的需求:輸出的內容不添加換行符,而且輸出的內容由字母加數字組成。
最近做了個Web模版,其中想用Base64背景圖。雖然網絡上有現成的編碼器,但總想自己實現一個。可能很多人不知道,JDK 8新提供的Base64類可以非常方便地處理此項任務:Base64 (Java Platform SE 8 ) 。
一、先選一張圖片
mm.png
二、建立HTML演示文件模版
test.html
<!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程序的註釋很清楚了,直接上代碼:
`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("任務結束..."); }}程序結果如下:
二進製圖片文件Base64碼:iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB...(此處省略n多字符)8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==任務結束...
四、最後設置
要在HTML文件模版test.html中引用Base64編碼內容,還有一步工作要做:將以下內容加到Base64編碼內容的開頭處: data:image/png;base64,
最終結果也就是類似這樣:
...(此處省略n多字符)8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==
之後,將這一長串字符串植入以下代碼行的url()括號中:
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總是那麼健壯和讓人放心。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。