一、base64編碼介紹
Base64是網絡上最常見的用於傳輸8Bit字節代碼的編碼方式之一,Base64編碼可用於在HTTP環境下傳遞較長的標識信息。采用Base64編碼具有不可讀性,即所編碼的數據不會被人用肉眼所直接看到。
在MIME格式的電子郵件中,base64可以用來將binary的字節序列數據編碼成ASCII字符序列構成的文本。使用時,在傳輸編碼方式中指定base64。使用的字符包括大小寫字母各26個,加上10個數字,和加號“+”,斜杠“/”,一共64個字符,等號“=”用來作為后綴用途。
Base64編碼要求把3個8位字節(3*8=24)轉化為4個6位的字節(4*6=24),之后在6位的前面補兩個0,形成8位一個字節的形式。 如果剩下的字符不足3個字節,則用0填充,輸出字符使用'=',因此編碼后輸出的文本末尾可能會出現1或2個'='。
為了保證所輸出的編碼位可讀字符,Base64制定了一個編碼表,以便進行統一轉換。編碼表的大小為2^6=64,這也是Base64名稱的由來。
二、base64圖片使用介紹
支持 PNG、GIF、JPG、BMP、ICO 格式。
支持查看圖片的具體大小。上傳過程無需網絡。
將圖片轉換為Base64編碼,可以讓你很方便地在沒有上傳文件的條件下將圖片插入其它的網頁、編輯器中。 這對於一些小的圖片是極為方便的,因為你不需要再去尋找一個保存圖片的地方。
假定生成的代碼為“data:image/jpeg;base64, .....”,那么你只需要全部復制,然后在插入圖片的時候,地址填寫這段代碼即可。
CSS中使用:
background-image: url("...");
HTML中使用:
<img src="..." />
圖片轉換Base64,無線開發、HTML5、CSS3必備的工具,CSS DataURI Base64 工具。
將圖片轉換成base64編碼的,在web網上一般用於小圖片上,不僅可以減少圖片的請求數量(集合到js、css代碼中),還可以防止因為一些相對路徑等問題導致圖片404錯誤。
三、base64圖片編碼大小與原圖文件大小之間的聯系
Base64編碼要求把3個8位字節(3*8=24)轉化為4個6位的字節(4*6=24),之后在6位的前面補兩個0,形成8位一個字節的形式。 如果剩下的字符不足3個字節,則用0填充,輸出字符使用’=’,因此編碼后輸出的文本末尾可能會出現1或2個’=’通過base64編碼原理我們知道,base64的圖片字符流中的每8個字符就有兩個是用0補充,而且字符流的末尾還可能存在‘=’號,我們可以通過這個原理計算圖片的文件流大小。
我們以以下base64編碼為例子:

1.需要計算文件流大小,首先把頭部的data:image/png;base64,(注意有逗號)去掉。
str=str.substring(22);
2.找到等號,把等號也去掉
int equalIndex= str.indexOf('=');
if(str.indexOf('=')>0)
{
str=str.substring(0, equalIndex);
}
3.原來的字符流大小,單位為字節
int strLength=str.length();
4.計算后得到的文件流大小,單位為字節
int fileLength=strLength*3/4;
5.輸出文件流大小
System.out.println(fileLength);
完整例子如下:
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import org.apache.commons.codec.binary.Base64; public class TestBase64 {
//java將圖片轉base64代碼示例 public static String encodeBase64File(String filePath){ File file = new File(filePath); FileInputStream inputFile = null; try { inputFile = new FileInputStream(file); byte[] buffer = new byte[(int) file.length()]; inputFile.read(buffer); inputFile.close(); String code = new String(Base64.encodeBase64(buffer)); return code; } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ if(inputFile != null){ try { inputFile.close(); } catch (IOException e) { e.printStackTrace(); } } } return null; } public static void main(String[] args) { String str=""; str=str.substring(22); int equalIndex= str.indexOf('='); if(str.indexOf('=')>0) { str=str.substring(0, equalIndex); } int strLength=str.length(); int fileLength=strLength*3/4; System.out.println(fileLength); } }
最好看下大小差別:

