Jboss .netty项目使用的netty包详解之 org.jboss.netty.handler.codec.base64

A.在讲具体类之前,先讲一下base64的编码/解码原理

Base64是一种通过将数据进行编码/解码,是一种可逆编码。我们经常发的邮件,它的内容就是通过这种编码進行加減碼,然後在網上進行傳輸。

原理其實很簡單,就是將3個字節的二進制數(共3*8=24bits)進行分組,分成4組,每組只有6位(26次方=64,就是字母表中的64個字母,所以叫base64,將每6位的數據對應字母表當中的字母進行編碼。

将待编码序列每3个字节分一组,如果分到最后一组,只有一个字节的话,那么,前6bits可以进行编码,但是还剩下2bits,这时候,我们补全6bits。这样就可以将一个字节编成了两个字节了。在这里有一个问题,我们解码的时候,我们不知道之前编码的时候补全了0。这时候,我们引入了base64padding补丁。我们将最后两个字节的编码结果用“=”表示,即"=="表示最后一个分组只有一个字节。同理,当最后一个分组只有两个字节。前12bits可以进行编码,编成两个字节,剩下4bits,补全两位0后进行编码,最后一个字节用“=”,表示编码时最后一个分组只有两个字节。

B.org.jboss.handler.codec.base64包下包含四个文件,一个枚举类,三个JAVA

枚举类:Base64Dialect,主要定义的Base64的三种不同编码(STANDARDURL_SAFEORDERED),对应的用于编码的字母表和解码表也有所不同,此外还定义了在编码时是否换行属性breakLinesByDefault

STANDARD:标准编码,除了A-Za-z,0-9外加上+-(索引值6263

URL_SAFE:URL安全编码,除了A-Za-z,0-9外加上-_(索引值6263

ORDERED:按顺序编码,同URL_SAFE使用相同的字母表,但是-_这两个在字母中的位置(索引值037不一样。

Java类:

1.Base64,一个工具类,用于对channelbuffer对象进行编码/解码的一个工具,的运用多态的思想,里边封装了多个encode,decode方法,这些方法最终都是调用encode4to3decode3to4这两个核心的方法,同时利用HeapChannelBufferFactory的实例,创建用于一个新的ChannelBuffer用于存放最后的处理结果。

ChannelBuffercb=HeapChannelBufferFactory.getInstance().getBuffer(ChannelBuffer.order(),(int)lenght);

2.Base64Encode,Base64Decode

这两个类分别继承了OneToOneEncode,OneToOneDecode,封了Base64Dialect这个枚举,此外,在Base64Encode里边,还封装了布尔类型,表示编码时是否换行。

这两个类只有一个核心方法,重写了encodedecode方法,里边核心,也是调用1当中讲的Base64这个工具类进行编码/解码处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值