一、诞生原因
解决某些系统在直接处理二进制数据时会出现异常的问题。例如:某些老旧路由系统在转发某些二进制数据时就会出现异常,即:不是所有的二进制数据都是可以传输的。
为了解决上述问题,将二进制数据进行编码为可见的数据,则可以解决上述问题。
标准制定者精心挑选了64个可见字符,分别如下:
- 小写英文字母系列(26个)
- 大写英文字母系列(26个)
- 数字系列(10个)
- “+”、“/”
二、步骤
- 将待转换的字符串每 3 个字节分为一组,每个字节占 8 bit,那么共有 24 个二进制位。
- 将上面的 24 个二进制位每 6 个一组,共分为 4 组。
- 在每组前面添加两个 0,每组由 6 个变为 8 个二进制位,总共 32 个二进制位,即 4 个字节。
- 计算每一个字节的值,根据 base64 表得到每个字节代表的字符,转换完成即可。
三、其他
- base64 算法是每 3 个字节转换为 4 个字节,即:转换完之后的数据数量是原数据的 4 / 3 。
- 若在 base64 编码的过程中,原数据最后省了 1 个或者 2 个数据,则需要按照如下步骤进行处理:
即:用“=”代表缺失的字节数量,用“0”补充缺失的位。
(SAW:Game Over!)