编码 / Base 64

一、诞生原因

解决某些系统在直接处理二进制数据时会出现异常的问题。例如:某些老旧路由系统在转发某些二进制数据时就会出现异常,即:不是所有的二进制数据都是可以传输的。

为了解决上述问题,将二进制数据进行编码为可见的数据,则可以解决上述问题。

标准制定者精心挑选了64个可见字符,分别如下:

  • 小写英文字母系列(26个)
  • 大写英文字母系列(26个)
  • 数字系列(10个)
  • “+”、“/”

二、步骤

  1. 将待转换的字符串每 3 个字节分为一组,每个字节占 8 bit,那么共有 24 个二进制位。
  2. 将上面的 24 个二进制位每 6 个一组,共分为 4 组。
  3. 在每组前面添加两个 0,每组由 6 个变为 8 个二进制位,总共 32 个二进制位,即 4 个字节。
  4. 计算每一个字节的值,根据 base64 表得到每个字节代表的字符,转换完成即可。

三、其他

  1. base64 算法是每 3 个字节转换为 4 个字节,即:转换完之后的数据数量是原数据的 4 / 3 。
  2. 若在 base64 编码的过程中,原数据最后省了 1 个或者 2 个数据,则需要按照如下步骤进行处理:

即:用“=”代表缺失的字节数量,用“0”补充缺失的位。

 

(SAW:Game Over!)


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部