1. import io.netty.buffer.ByteBuf;
    2. import io.netty.channel.ChannelHandlerContext;
    3. import io.netty.handler.codec.MessageToMessageDecoder;
    4. import org.msgpack.MessagePack;
    5. import java.util.List;
    6. /*基于MessagePack的解码器,反序列化*/
    7. public class MsgPackDecoder extends MessageToByteEncoder<ByteBuf> {
    8. @Override
    9. protected void decode(ChannelHandlerContext ctx, ByteBuf msg, List<Object> out)
    10. throws Exception {
    11. final int length = msg.readableBytes();
    12. final byte[] array = new byte[length];
    13. msg.getBytes(msg.readerIndex(),array,0,length);
    14. MessagePack messagePack = new MessagePack();
    15. out.add(messagePack.read(array,User.class));
    16. }
    17. }