今日无事,闲来Base64

🍀 作者:iamteapot
📌 每日一句:今日听君歌一曲,暂凭杯酒长精神!
🎨 ps:今天和大家聊聊Base64编码与解码的问题。

什么是Base64编码?

​ Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法。可查看RFC2045~RFC2049,上面有MIME的详细规范。

​ Base64编码是从二进制到字符的过程,可用于在HTTP环境下传递较长的标识信息。采用Base64编码具有不可读性,需要解码后才能阅读。

Base64编码

编码流程

​ 以pot为例子,对其进行Base64加密

(1)对原始数据,分字节,求二进制字符串;

ASCII字符pot
十进制112111116
二进制011100000110111101110100

(2)对二进制串,6位为一组进行分组,不足末尾补0;

ASCII字符pot
十进制112111116
二进制011100000110111101110100
每6个bit为一组011100000110111101110100

(3)在各分组前面补2个0成8位,求各分组的十进制值,根据十进制对应上表找编码字符;

对照索引表如下

索引对应字符索引对应字符索引对应字符索引对应字符
0A17R34i51z
1B18S35j520
2C19T36k531
3D20U37l542
4E21V38m553
5F22W39n564
6G23X40o575
7H24Y41p586
8I25Z42q597
9J26a43r608
10K27b44s619
11L28c45t62+
12M29d46u63/
13N30e47v
14O31f48w
15P32g49x
16Q33h50y
ASCII字符pot
十进制112111116
二进制011100000110111101110100
每6个bit为一组011100000110111101110100
高位补000011100000001100011110100110100
对应的Base64索引2866152
对应base64字符cG90

(4)字节数对3取余数,余数为0,不加等号;余数为1,在上述编码符号串的末尾加2个等号;余数为2,末尾加1个等号。

所以pot的Base64编码就是cG90

Base64解码

第一步,将每4个字符为一组,查找上表,找到每个字符对应的ASCII值

第二步,将4个ASCII值写成二进制形式,并将每个二进制的前2个00去掉

第三步,将剩下的24位二进制位分成3份,即3个字节

第四步,查找ASCII值表(下表),找到每个字节对应的字符。

其实就是将上述过程反过来一遍可以了。这里就不再赘述。


本文为作者原创,转载请标明出处!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值