java base64 长度限制_如果输入长度不能被3整除,为什么base64编码需要填充?

什么是填充字符?

填充字符有助于满足长度要求并且没有任何意义 .

Decimal Example of Padding: 鉴于任意要求所有字符串的长度为8个字符,数字640可以满足此要求,使用前面的0作为填充字符,因为它们没有任何意义,"00000640" .

二进制编码

The Byte Paradigm: 该字节是事实上的标准测量单位,任何编码方案必须与字节有关 .

Base256 恰好适合这种范式 . 一个字节等于base256中的一个字符 .

Base16 ,十六进制或十六进制,每个字符使用4位 . 一个字节可以表示两个base16字符 .

与base256和base16不同, Base64 不能均匀地适合字节范例 . 所有base64字符都可以用6位表示,比完整字节短2位 .

我们可以将base64编码与字节范例表示为一个分数:每字符6比特,每字节8比特 . 减少此分数是超过4个字符的3个字节 .

这个比率,每4个base64个字符3个字节,是我们在编码base64时要遵循的规则 . Base64 encoding can only promise even measuring with 3 byte bundles, 与base16和base256不同,其中每个字节都可以独立存在 .

所以 why 是鼓励填充,即使编码可以正常工作没有填充字符?填充字符明确地表示那些额外的点应该是空的,排除任何歧义或潜在的讨厌的错误 . 填充允许我们解码base64编码,承诺没有丢失的比特 . 如果没有填充,则不再明确承认三字节包中的测量,并且我们无法再保证在没有附加信息的情况下精确再现原始编码 .

例子

“BASE64”函数中的每个字符使用一个字节(base256) . 然后我们将其转换为base64 .

BASE64("") = "" (No bytes used. 0%3=0.)

BASE64("f") = "Zg==" (One byte used. 1%3=1.)

BASE64("fo") = "Zm8=" (Two bytes. 2%3=2.)

BASE64("foo") = "Zm9v" (Three bytes. 3%3=0.)

BASE64("foob") = "Zm9vYg==" (Four bytes. 4%3=1.)

BASE64("fooba") = "Zm9vYmE=" (Five bytes. 5%3=2.)

BASE64("foobar") = "Zm9vYmFy" (Six bytes. 6%3=0.)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值