Netty实现数据格式转换的方式是继承实现ByteToMessageDecoder和MessageToByteEncoder。
ByteToMessageDecoder继承ChannelInboundHandlerAdapter
MessageToByteEncoder继承ChannelOutboundHandlerAdapter
ByteToMessageDecoder在数据流转过程中承担角色如下所示:
MessageToByteEncoder在数据流转过程中承担角色如下所示:
1、 如果需要做数据格式的转换,可以使用MessageToMessageDecoder和MessageToMessageEncoder;
2、 如果需要处的ByteBuf太长,可以抛出TooLongFrameException;
3、 如果需要一个类实现编码和解码可以对应实现ByteToMessageCodec和MessageToMessageCodec
4、 如果一类实现编码和解码觉得耦合严重,可以使用CombinedChannelDuplexHandler
Netty中有哪些自带的ChannelHandler?
1、 SslHandler:负责对请求进行加密和解密,是放在ChannelPipeline中的第一个ChannelHandler
2、 HttpClientCodec和HttpServerCodec:HttpClientCodec负责将请求字节解码为HttpRequest、HttpContent和LastHttpContent消息,以及对应的转为字节;HttpServerCodec负责服务端中将字节码解析成HttpResponse、HttpContent和LastHttpContent消息,以及对应的将它转为字节
HttpServerCodec 里面组合了HttpResponseEncoder和HttpRequestDecoder
HttpClientCodec 里面组合了HttpRequestEncoder和HttpResponseDecoder
1、 HttpObjectAggregator: 负责将http聚合成完整的消息,而不是原始的多个部分
2、 HttpContentCompressor和HttpContentDecompressor:HttpContentCompressor用于服务器压缩数据,HttpContentDecompressor用于客户端解压数据
3、 IdleStateHandler:连接空闲时间过长,触发IdleStateEvent事件
4、 ReadTimeoutHandler:指定时间内没有收到任何的入站数据,抛出ReadTimeoutException异常,并关闭channel
5、 WriteTimeoutHandler:指定时间内没有任何出站数据写入,抛出WriteTimeoutException异常,并关闭channel
6、 DelimiterBasedFrameDecoder:使用任何用户提供的分隔符来提取帧的通用解码器
7、 FixedLengthFrameDecoder:提取在调用构造函数时的定长帧
8、 ChunkedWriteHandler:将大型文件从文件系统复制到内存【DefaultFileRegion进行大型文件传输】