在李林峰《netty权威指南第二版》中第123页,作者将之前的EchoServer和EchoClient改造,同时编写自定义MsgpackEncoder和MsgpackDecoder编解码类;测试传输pojo对象的编解码功能,在改造完clien端后,123页下面说服务端代码与客户端类似,请参考书中附带的源码;但是源码中并没有这一节内容,新手如果想测试一遍书中的例子,一时写不出来,参考这里,其实很简单,EchoServer几乎不用动,只改EchoServerHandler的代码:
public class EchoServerHandler extends ChannelHandlerAdapter { @Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { System.out.println("server receive the msgpack message : "+msg+""); // 原路返回给客户端 ctx.writeAndFlush(msg); } @Override public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception { cause.printStackTrace(); // 释放资源 ctx.close(); } }
另外测试过程中发现,在pojo对象类(书中为UserInfo)上面不加@Message注解的话,会收不到消息,不知道是不是作者忘了,注解所属类
import org.msgpack.annotation.Message;还有在EchoClientHandler中向服务端发送一个pojo对象,经过MessagePack编解码后,在EchoServerHandler中的channelRead方法中打印的msg为pojo对象的toString方法内容,不可以直接将msg转换为UserInfo,否则会报java.lang.ClassCastException: org.msgpack.type.ArrayValueImpl cannot be cast to UserInfo
当我转为List<UserInfo>,循环list,打印list.get(0)输出null,打印list.get(0).getName()报org.msgpack.type.NilValue cannot be cast to UserInfo;如果直接输出list就和输出msg的效果一样。
参考地址:http://blog.youkuaiyun.com/u012247397/article/details/52396257