標籤:

Base64編碼

Base64編碼文章分類:Java編程Base641.什麼是Base64?按照RFC2045的定義,Base64被定義為:Base64內容傳送編碼被設計用來把任意序列的8位位元組描述為一種不易被人直接識別的形式,這種加密方式主要就是「防君子不防小人」。即達到一眼望去完全看不出內容即可。2. 演算法詳解 Base64編碼要求把3個8位位元組(3*8=24)轉化為4個6位的位元組(4*6=24),之後在6位的前面補兩個0,形成8位一個位元組的形式。 如果剩下的字元不足3個位元組,則用0填充,輸出字元使用"=",因此編碼後輸出的文本末尾可能會出現1或2個"="。具體轉化形式間下圖:字元串「張3」11010101 11000101 0011001100110101 00011100 00010100 001100113. Base64編碼表為了保證所輸出的編碼位可讀字元,Base64制定了一個編碼表,以便進行統一轉換。編碼表的大小為2^6=64,這也是Base64名稱的由來。 Base64編碼表 碼值 碼 碼值 碼 碼值碼 碼值 碼 0 A 17 R 34 i 51 z 1 B 18 S 35 j 52 0 2 C 19 T 36 k 53 1 3 D 20 U 37 l 54 2 4 E 21 V 38 m 55 3 5 F 22 W 39 n 56 4 6 G 23 X 40 o 57 5 7 H 24 Y 41 p 58 6 8 I 25 Z 42 q 59 7 9 J 26 a 43 r 60 8 0 K 27 b 44 s 61 9 11 L 28 c 45 t 62 + 12 M 29 d 46 u 63 / 13 N 30 e 47 v 14 O 31 f 48 w (pad) = 15 P 32 g 49 x 16 Q 33 h 50 y編碼詳解1. 不加後補位的字元串「abC」01100001 01100010 0100001100011000 00010110 00001001 0000001124 22 9 3查表可以得到編碼值為:「YWJD」。2. 加後補位的字元串「ab」:01100001 0110001000011000 00010110 00001000 0000000024 22 8 -由於不夠24個位元組位,所以我們要加8個0位元組位以湊夠24個。「-」表示增加的補位,編碼後應為「=」,所以可以得到編碼後的字元串為「YWI=」。3. 加後補位的字元串「a」:0110000100011000 00010000 00000000 0000000024 16 - -同樣,編碼後的字元串為「YQ==」,只是這裡出現了兩個「=」。
推薦閱讀:

《Code 編碼:隱匿在計算機軟硬體背後的語言》讀書筆記
業力與大腦神經編碼記憶 腦可塑性-大腦皮層增大-記憶學習經歷固化 大腦重構 關鍵期MeCP2蛋白 中風大腦修復
讓人困擾的Python 2編碼
你好,類型(二):Lambda calculus

TAG:編碼 |