文章目录
- Base64编码解码原理
- 参考
Base64编码解码原理
首先有一个64个字符的转换表。
待转转换的数据,3个字节位一组,3个字节24位,刚好可以分成4个6位的对象,
每个6位对象前补2个0,就变成了4个字节。这就可以对应转换表中的字符了。这就是转换后的字符。
也就是原本3个字节,转换后变成了4个字节的ANSII字符。
如果待转换数据字节数不是3的倍数,比如是4个字节,前3字节按照上面规则转换,后1个字节,可以右侧补4个0,形成12位,转成2个6位对象,生成两个转换后字节,
这样的情况,要在转换后的字符串后追加2个‘=’。
比如是5个字节,前3字节按照上面规则转换,后2个字节,可以右侧补2个0,形成18位,转成3个6位对象,生成两个转换后字节,
这样的情况,要在转换后的字符串后追加1个‘=’。(补2个0,追加1个‘=’;补4个0,追加2个‘=’;)
参考
C++ Boost库实现 Base64编解码