Java 8實現(xiàn)圖片BASE64編解碼
前言
Basic編碼是標準的BASE64編碼,用于處理常規(guī)的需求:輸出的內容不添加換行符,而且輸出的內容由字母加數(shù)字組成。
最近做了個Web模版,其中想用Base64背景圖。雖然網(wǎng)絡上有現(xiàn)成的編碼器,但總想自己實現(xiàn)一個??赡芎芏嗳瞬恢?,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程序
這里將實現(xiàn)Base64編解碼的雙向實現(xiàn),盡管本例中只需要用到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數(shù)組。
*
*/
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數(shù)組。
* @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,
最終結果也就是類似這樣:
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIAAAACACAYAAADDPmHLAAAABGdBTUEAALGPC/xhBQAAACB ...(此處省略n多字符) 8xNTIwL2Vhc3lpY29uLmNuL2Vhc3lpY29uLmNuL2Nkbi1pbWcuZWFzeWljb24uY24vcG5nLzEwODcwLzEwODcwODYucG5nPLffdwAAAABJRU5ErkJggg==
之后,將這一長串字符串植入以下代碼行的url()括號中:
background: url() no-repeat center center;
如果圖片是JPG格式,請將上面data:image/png;base64中的png改為jpeg,如果是GIF格式就改為gif。好了,刷新頁面,看看結果:

有圓圈圈是因為我們設置了一些CSS3特效。
我們還實現(xiàn)了Base64解碼,并生成一個新的mm2.png圖片,在圖片瀏覽器中打開mm2.png,效果應該跟mm.png是一模一樣的。
其實,每次JDK新版發(fā)布,都蘊藏著許多大大小小的更新,只是你是否有意去發(fā)掘它而已。Java總是那么健壯和讓人放心。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關文章
客戶端Socket與服務端ServerSocket串聯(lián)實現(xiàn)網(wǎng)絡通信
這篇文章主要為大家介紹了客戶端Socket與服務端ServerSocket串聯(lián)實現(xiàn)網(wǎng)絡通信的內容詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03
基于HttpServletResponse 相關常用方法的應用
本篇文章小編為大家介紹,基于HttpServletResponse 相關常用方法的應用,需要的朋友參考下2013-04-04
java的Jackson框架實現(xiàn)輕易轉換JSON
本篇文章主要介紹了java的Jackson框架實現(xiàn)輕易轉換JSON,Jackson將Java對象轉換成json對象和xml文檔,同樣也可以將json、xml轉換成Java對象,有興趣的可以了解一下。2017-02-02

