就最根本的作用来说,把base64编码解码看做一个黑盒,那只有对byte[]类型的数据而言,是无失真的,也就是byte[]编码后得到的,解码后就是原来的byte[]。而本质上其他类型的数据string 还是file等,也都是转byte[]才进行编码。问题在于解码的时候,由于编码后的内容是码表中的下列字符,解码时应该无论哪种编码格式都是能转换原来的编码入参byte[],是不失真的(因为下列字符byte[] string互转看上去是不受编码格式影响的,其他字符则会可能失真),而得到这个原始bye[]后怎么转回原来的String 或file,这个时候就得注意了,举个例子,如果byte[] bytes = "测试".getbyte("utf-8"); byte[] encode = base64.encode(bytes); byte[] decode = base64.decode(encode); 这个时候一般bytes是等于decode,而怎么让decode转为"测试"呢,则必须decode 以utf-8的格式来转。其他情况类似。备忘于此。
Base64编码表
码值 | 字符 | 码值 | 字符 | 码值 | 字符 | 码值 | 字符 | |||
---|---|---|---|---|---|---|---|---|---|---|
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 | / |