编程小知识 之 Base64 编码

本文详细介绍了Base64编码的工作原理,包括步骤、编码对照表,并通过实例演示如何对二进制数据进行编码,以及处理非整数字节的情况。适合开发者理解和应用在邮件、API传输等场景。

本文简述了 Base64 编码的一些知识

简介

在一些 支持可打印字符(而不(完善)支持其他字符) 的开发场景下(譬如原始的电子邮件中),为了能够传输存储二进制数据(广义上的非打印字符),我们需要一种将二进制数据转换为可打印字符的编码方式, Base64 就是这么一种编码方式.

基础

Base64 编码的步骤如下:

  • 将待转换的字节数组(即二进制数据)按每 3 个字节分为一组(共 3 x 8 = 24 bit(二进制位))
  • 将上述 24 bit 按每 6 bit 一组重新分为 4 组
  • 分别计算上面 4 组的索引值(6 bit 一组)
  • 根据编码对照表完成转换

Base64 选用 ‘A-Z’ ‘a-z’ ‘0-9’ ‘+’ ‘/’ 这 64 个可打印字符作为编码字符,外加 ‘=’ 作为填充字符,具体的编码对照表如下所示:

数值字符数值字符数值字符数值字符
0A16Q32g48w
1B17R33h49x
2C18S34i50y
3D19T35j51z
4E20U36k520
5F21V37l531
6G22W38m542
7H23X39n553
8I24Y40o564
9J25Z41p575
10K26a42q586
11L27b43r597
12M28c44s608
13N29d45t619
14O30e46u62+
15P31f47v63/
示例

现在我们来对二进制数据(如果用 ASCII 码表示的话就是字符串 ABC)进行 Base64 编码

010000010100001001000011 ( A B C ) 010000010100001001000011(ABC) 010000010100001001000011(ABC)

转换过程如下表所示:

文本 A B C
ASCII编码 65 66 67
二进制位 010000010100001001000011
索引 16 20 9 3
Base64编码 Q U J D

Base64 按 3个字节 分组编码,对于字节数组长度不是 3 字节倍数的情况,我们需要进行填充: 先使用 0 字节值在末尾补足,使字节数组长度能够被 3 整除,然后再进行 Base64 编码,最后在编码后的 Base64 文本后加上一个或两个 ‘=’ 号, 用以代表补足的字节数.

下面的示例展示了以下二进制数据的转换过程:

01000001 ( A ) 0100001001000011 ( B C ) 01000001(A) \\ 0100001001000011(BC) 01000001(A)0100001001000011(BC)

文本 A
ASCII编码 65
二进制位 01000001
二进制位(补0) 010000010000000000000000
索引 16 16
Base64编码 Q Q = =
文本 B C
ASCII编码 66 67
二进制位 0100001001000011
二进制位(补0) 010000100100001100000000
索引 16 36 12
Base64编码 Q k M =
参考资料
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值