ToBase64String 为什么会有==

用ToBase64String方法可以在不丢失数据的情况下将字节数组转成字符串

在ToBase64String方法中,会对字节数组中的连续三字节进行一次编码,编码得的字符串长度为4位,而且得出来的4位的字符串里面的字符肯定是由大小写字母、数字(0~9)、+、/组成,例如有一个字节数组{212,36,25,23,45,65},ToBase64String方法会将这个数组分成2个数组,分别为{212,36,25}和{23,45,65},{212,36,25}计算出来的字符串是“1CQZ”,而{23,45,65} 是“Fy1B”,如果是{212,36,25,23},则先分成两个数组,{212,36,25}和{23},{212,36,25}已经计算过了,但{23}不足三字节,怎么办?{23}会转换成“Fw==”,所以{212,36,25}和{23,45,65},{212,36,25}转换出来的字符串是“1CQZFy1B”,{212,36,25,23}是“1CQZFw==”。

为什么会这样转换呢?

在ToBase64String中,利用了52个大小写字母,10个数字,“+”和“/”一共64个字符组成三个不同的矩阵,因为这三个矩阵比较大,不好放出来,所以你可以在附件中看到这在个矩阵的情况。当一个数组中只由1个字节组成时,在ToBase64String方法中只会用到第一个矩阵,当由2个字节组成时,在ToBase64String方法中会用到第一和第二个矩阵,当由3个字节组成时, ToBase64String方法中就会用全1、2、3这三个矩阵。


而在这三个矩阵中,是一阵扣一阵。例如要用到第三个矩阵,就要求从第一个矩阵计算出第二个矩阵的起码编码,根据字节的大小计算第二矩阵经过偏移量得出的编码,再由每二矩阵编码找到第三矩阵的偏移编码,找到第三矩阵编码后,最后由第一矩阵的纵码+第二矩阵纵码+第三矩阵纵码+第三矩阵横码=最后的转换字符串.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值