Base64
1.什么是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 00110011 00110101 00011100 00010100 00110011 3. 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 01000011 00011000 00010110 00001001 00000011 24 22 9 3 查表可以得到编码值为:“YWJD”。 2. 加后补位的字符串“ab”: 01100001 01100010 00011000 00010110 00001000 00000000 24 22 8 - 由于不够24个字节位,所以我们要加8个0字节位以凑够24个。“-”表示增加的补位,编码后应为“=”,所以可以得到编码后的字符串为“YWI=”。 3. 加后补位的字符串“a”: 01100001 00011000 00010000 00000000 00000000 24 16 - - 同样,编码后的字符串为“YQ==”,只是这里出现了两个“=”。 |
|
来自: CevenCheng > 《基础》