参考文章http://www.cnblogs.com/hongru/archive/2012/01/14/2321397.html
--base64的编码都是按字符串长度,以每3个8bit的字符为一组
--然后针对每组,首先获取每个字符的ASCII编码
--然后将ASCII编码转换成8bit的二进制,得到一组3*8=24bit的字节
--然后再将这24bit划分为4个6bit的字节,并在每个6bit的字节前面都填俩个高位0,得到4个8bit的字节
--然后将这4个8bit的字节转换成10进制,对照base64编码表,得到对应编码后的字符
其中需要注意的俩点:
1.要求编码字符是8bit,所以必须在ASCII范围内,不是ASCII码的需要转为ASCII码
2.如果被编码的字符长度不是3的倍数时,需要在低位用0补齐,对应输出=
base编码表
Base64 编码表 | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
Value | Char | Value | Char | Value | Char | Value | Char | |||
0 | A | 16 | Q | 32 | g | 48 | w | |||
1 | B | 17 | R | 33 | h | 49 | x | |||
2 | C | 18 | S | 34 | i | 50 | y | |||
3 | D | 19 | T | 35 | j | 51 | z | |||
4 | E | 20 | U | 36 | k | 52 | 0 | |||
5 | F | 21 | V | 37 | l | 53 | 1 | |||
6 | G | 22 | W | 38 | m | 54 | 2 | |||
7 | H | 23 | X | 39 | n | 55 | 3 | |||
8 | I | 24 | Y | 40 | o | 56 | 4 | |||
9 | J | 25 | Z | 41 | p | 57 | 5 | |||
10 | K | 26 | a | 42 | q | 58 | 6 | |||
11 | L | 27 | b | 43 | r | 59 | 7 | |||
12 | M | 28 | c | 44 | s | 60 | 8 | |||
13 | N | 29 | d | 45 | t | 61 | 9 | |||
14 | O | 30 | e | 46 | u | 62 | + | |||
15 | P | 31 | f | 47 | v | 63 | / |
例子请参考上面的链接
下面讲一下base64的作用:请注意,base64是编解码方式,不是加解密方式。区别在于前者虽然不是明文,但可以轻易解析,后者可能不是明文,并且不易解析。
参照上面的base64编码表可以知道,通过base64可以将string(一般会将string类型的数据转换为data类型)的东西转换为A-Z,a-z,0-9,+,/,=,也就是转换为ACII码的方式。
在不同的设备上,对数据的解析方式不大相同,所以容易出现乱码的情况,而一个统一的编码方式,可以避免乱码的出现,那就是base64。但是base64也存在其缺点,如上面讲到base64转换的过程中会有高位补俩个0的步骤,那么就会是编码后的数据至少是编码前数据的4/3倍(算的应该对,不好意思,数学不好,嘿嘿!)
总之,base64的作用是让数据不以明文传输and是一个轻量级的加密方式(为什么这里叫加密,因为不是明文,一般人不知道是什么)。
为什么叫base64,请瞥一眼base64编码表,秒懂!
总结起来,base64是用来避免乱码的