Netty学习007-编解码器

首先了解下什么是编码器什么是解码器

 解码器:负责将消息从字节或其他序列形式转成指定的消息对象。
 编码器:将消息对象转成字节或其他序列形式在网络上传输。

在Netty中无论是编码器还是解码器都是实现了ChannelHandlerAdapter,一种特殊的ChannelHandler

先说解码器(Decoder)↓
解码器负责把一种数据转换成另一种数据(比如二进制数据,按照私有通信协议转换成对应的Java实体对象),在实际使用过程中将入站数据转换格式后传递到ChannelPipeline中的下一个ChannelInboundHandler进行处理。
在Netty中主要提供了抽象基类ByteToMessageDecoderMessageToMessageDecoder
在这里插入图片描述

1)  ByteToMessageDecoder: 用于将字节转为消息,需要检查缓冲区是否有足够的字节
2)  ReplayingDecoder: 继承ByteToMessageDecoder,不需要检查缓冲区是否有足够的字节,但是 ReplayingDecoder速度略慢于ByteToMessageDecoder,同时不是所有的ByteBuf都支持。
选择:项目复杂性高则使用ReplayingDecoder,否则使用 ByteToMessageDecoder
3MessageToMessageDecoder: 用于从一种消息解码为另外一种消息(例如POJOPOJO

ByteToMessageDecoder解码器

public class ToIntegerDecoder extends ByteToMessageDecoder {
    @Override
   public void decode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) throws Exception {
    if (in.readableBytes() >= 4) {
        out.add(in.readInt());
    } }
}
//参数解释
//Bytubuf:需要解码的二进制数据。
//List<Object>:解码后的有效报文列表,我们需要将解码后的报文添加到这个List中。之所以使用一个List表示,是因为考虑到粘包问题,因此入参的in中可能包含多个有效报文。
//当然,也有可能发生了拆包,in中包含的数据还不足以构成一个有效报文,此时不往List中添加元素即可。

ByteToMessageDecoder提供的一些常见的实现类

FixedLengthFrameDecoder:定长协议解码器,我们可以指定固定的字节数算一个完整的报文
LineBasedFrameDecoder:  行分隔符解码器,遇到\n或者\r\n,则认为是一个完整的报文
DelimiterBasedFrameDecoder:  分隔符解码器,与LineBasedFrameDecoder类似,只不过分隔符可以自己指定
LengthFieldBasedFrameDecoder:长度编码解码器,将报文划分为报文头/报文体,根据报文头中的Length字段确定报文体的长度,因此报文提的长度是可变的
JsonObjectDecoder:json格式解码器,当检测到匹配数量的"{" 、”}”或”[””]”时,则认为是一个完整的json对象或者json数组

MessageToMessageDecoder解码器
yteToMessageDecoder是将二进制流进行解码后,得到有效报文。而MessageToMessageDecoder则是将一个本身就包含完整报文信息的对象转换成另一个Java对象,一个个比较容易的理解的类比案例是Java Web编程,通常客户端浏览器发送过来的二进制数据,已经被web容器(如tomcat)解析成了一个HttpServletRequest对象,但是我们还是需要将HttpServletRequest中的数据提取出来,封装成我们自己的POJO类,也就是从一个Java对象(HttpServletRequest)转换成另一个Java对象(我们的POJO类)

/**
* 参数msg,需要进行解码的参数。例如ByteToMessageDecoder解码后的得到的包含完整报文信息
* List<Object> out参数:将msg经过解析后得到的java对象,添加到放到List<Object> out中
*/
protected abstract void decode(ChannelHandlerContext ctx, I msg, List<Object> out) throws Exception;

编码器如下
Netty提供了对应的编码器实现MessageToByteEncoder和MessageToMessageEncoder,二者都实现ChannelOutboundHandler接口
在这里插入图片描述
相对来说,编码器比解码器的实现要更加简单,原因在于解码器除了要按照协议解析数据,还要要处理粘包、拆包问题;而编码器只要将数据转换成协议规定的二进制格式发送即可

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值