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

本文介绍使用Netty实现Msgpack编解码的过程,包括如何修改EchoServerHandler处理POJO对象,解决未添加@Message注解导致的问题,及避免ClassCastException异常的方法。

        在李林峰《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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值