MessagePack编解码功能测试代码补齐

来源:互联网 发布:php 用pack打包数据包 编辑:程序博客网 时间:2024/05/19 06:35

        在李林峰《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.csdn.net/u012247397/article/details/52396257