【第22篇】Netty解码器剖析与入站出站处理器

Netty的处理器重要概念

  • 1、Netty的处理器可以分为两大类:入站处理器与出站处理器
  • 2、入站处理器的顶层是ChannelInboundHandler,而出站处理器的顶层是ChannelOutboundHandler
  • 3、数据处理器时常用的各种编解码,本质上都是处理器
  • 4、编解码器:物流我们向网络希尔的数据是什么类型(int,char,String 二进制等)数据在网络传递时候,其都是以字节流的形式呈现的,将数据由原本的形式转换为字节流的操作成为编码encode,将数据由字节流转换成原本的格式或是其他格式的操作称为解码(decode),编解码统称为codec
  • 5、编码:本质上是一种出站的处理器,因此一定是ChannelOutboundHandler
  • 6、解码:本质上是一种入站的处理器,因此一定是ChannelInboundHandler
  • 7、在Netty中,编码器通常以XXXEncoder命名,解码器通常以XXXDecoder命名
    *入站处理器代码使用如:
public class MyServerHandler extends SimpleChannelInboundHandler {

    @Override
    protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {
        System.out.println(ctx.channel().remoteAddress() + ", " + msg);
        ctx.channel().writeAndFlush("from server: " + UUID.randomUUID());
    }

    @Override
    public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
        cause.printStackTrace();
        ctx.close();
    }
}
【第22篇】Netty解码器剖析与入站出站处理器_第1张图片
SimpleChannelInboundHandler
【第22篇】Netty解码器剖析与入站出站处理器_第2张图片
ChannelInboundHandler
【第22篇】Netty解码器剖析与入站出站处理器_第3张图片
ChannelOutboundHandler

关于Netty编解码的重要结论

  • 1、无论是编码器还是解码器,其所接收的消息类型,必须要与待处理的参数类型一致,否则该编码器或解码器并不会被执行
  • 2、在解码器进行数据解码时候,一定要记得判断(ByteBuf)中的数据是否足够,否则将会产生一些问题

组合方式管理通道句柄

  • CombinedChannelDuplexHandler,从代码里面看出来,它基础ChannelDuplexHandler管道,此类有诸多重要的方法如:bind,channelRead,
    connectdisconnectderegister,而它有一个内部类DelegatingChannelHandlerContext,它也有比较多重要的方法,如:alloc,attr,bind这里不写了,请看【DelegatingChannelHandlerContext方法】截图
【第22篇】Netty解码器剖析与入站出站处理器_第4张图片
CombinedChannelDuplexHandler关系图

DelegatingChannelHandlerContext方法

【第22篇】Netty解码器剖析与入站出站处理器_第5张图片
DelegatingChannelHandlerContext方法

你可能感兴趣的:(【第22篇】Netty解码器剖析与入站出站处理器)