前言:
前面學習總結了平時開發中遇見的各種資料加密方式,最終都會對加密後的二進位制資料進行Base64編碼,起到一種二次加密的效果,其實呢Base64從嚴格意義上來說的話不是一種加密演算法,而是一種編碼演算法,為何要使用Base64編碼呢?它解決了什麼問題?這也是本文探討的東西?
其他幾種加密方式:
什麼Base64演算法?
Base64是網路上最常見的用於傳輸8Bit位元組程式碼的編碼方式之一,Base64並不是安全領域的加密演算法,其實Base64只能算是一個編碼演算法,對資料內容進行編碼來適合傳輸。標準Base64編碼解碼無需額外資訊即完全可逆,即使你自己自定義字符集設計一種類Base64的編碼方式用於資料加密,在多數場景下也較容易破解。Base64編碼本質上是一種將二進位制資料轉成文字資料的方案。對於非二進位制資料,是先將其轉換成二進位制形式,然後每連續6位元(2的6次方=64)計算其十進位制值,根據該值在A--Z,a--z,0--9,+,/ 這64個字元中找到對應的字元,最終得到一個文字字串。基本規則如下幾點:
- 標準Base64只有64個字元(英文大小寫、數字和+、/)以及用作字尾等號;
- Base64是把3個位元組變成4個可列印字元,所以Base64編碼後的字串一定能被4整除(不算用作字尾的等號);
- 等號一定用作字尾,且數目一定是0個、1個或2個。這是因為如果原文長度不能被3整除,Base64要在後面新增\0湊齊3n位。為了正確還原,新增了幾個\0就加上幾個等號。顯然新增等號的數目只能是0、1或2;
- 嚴格來說Base64不能算是一種加密,只能說是編碼轉換。
下圖為Base64編碼表
Base64編碼的用處?
在計算機中任何資料都是按ascii碼儲存的,而ascii碼的128~255之間的值是不可見字元。而在網路上交換資料時,比如說從A地傳到B地,往往要經過多個路由裝置,由於不同的裝置對字元的處理方式有一些不同,這樣那些不可見字元就有可能被處理錯誤,這是不利於傳輸的。所以就先把資料先做一個Base64編碼,統統變成可見字元,這樣出錯的可能性就大降低了。
Base64具體實現
1.)字串進行Base64編碼
String encodedString = Base64.encodeToString("whoislcj".getBytes(), Base64.DEFAULT);
Log.e("Base64", "Base64---->" + encodedString);
2.)字串進行Base64解碼
String decodedString =new String(Base64.decode(encodedString,Base64.DEFAULT)); Log.e("Base64", "Base64---->" + decodedString);
3.)對檔案進行Base64編碼
File file = new File("/storage/emulated/0/pimsecure_debug.txt"); FileInputStream inputFile = null; try { inputFile = new FileInputStream(file); byte[] buffer = new byte[(int) file.length()]; inputFile.read(buffer); inputFile.close(); encodedString = Base64.encodeToString(buffer, Base64.DEFAULT); Log.e("Base64", "Base64---->" + encodedString); } catch (Exception e) { e.printStackTrace(); }
4.)對檔案進行Base64解碼
File desFile = new File("/storage/emulated/0/pimsecure_debug_1.txt"); FileOutputStream fos = null; try { byte[] decodeBytes = Base64.decode(encodedString.getBytes(), Base64.DEFAULT); fos = new FileOutputStream(desFile); fos.write(decodeBytes); fos.close(); } catch (Exception e) { e.printStackTrace(); }
5.)針對Base64.DEFAULT引數說明
無論是編碼還是解碼都會有一個引數Flags,Android提供了以下幾種
-
DEFAULT 這個引數是預設,使用預設的方法來加密
-
NO_PADDING 這個引數是略去加密字串最後的”=”
-
NO_WRAP 這個引數意思是略去所有的換行符(設定後CRLF就沒用了)
-
CRLF 這個引數看起來比較眼熟,它就是Win風格的換行符,意思就是使用CR LF這一對作為一行的結尾而不是Unix風格的LF
-
URL_SAFE 這個引數意思是加密時不使用對URL和檔名有特殊意義的字元來作為加密字元,具體就是以-和_取代+和/
總結:
Base64編碼看似簡單,但是其在實際開發中使用相當廣泛。目前專案中只是用到這麼多,以後用到更復雜的情況的時候再做補充。