netty中收到的消息是ByteBuf类型,需要先将其转换为java对象,才能做业务处理。发出消息时则需要先将java对象转为ByteBuf。解码器和编码器就是专门用来处理这种转换的,收到消息时解码,发出消息时编码。

启动配置
修改netty启动代码,现在有三个自定义类,多了解码器和编码器。解码器是入站处理,编码器是出站处理。
ServerBootstrap b = new ServerBootstrap();
b.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class)
.childHandler(new ChannelInitializer<SocketChannel>() {
@Override
public void initChannel(SocketChannel ch) throws Exception {
ch.pipeline().addLast(new MyDecoder());//解码器
ch.pipeline().addLast(new MyEncoder());//编码器
ch.pipeline().addLast(new MyHandler());//业务处理
}
}).option(ChannelOption.SO_BACKLOG, 128)
.childOption(ChannelOption.SO_KEEPALIVE, true);
解码
继承MessageToMessageDecoder即可,在这里将收到的ByteBuf消息转换成字符串。可能你读取到的是一

本文详细介绍Netty中消息的编解码过程,包括自定义解码器和编码器的实现,以及如何在启动配置中应用。通过示例代码讲解如何将ByteBuf转换为Java对象并进行业务处理,同时介绍Netty预设的编解码类。
最低0.47元/天 解锁文章
1718

被折叠的 条评论
为什么被折叠?



