Netty学习之自定义协议

通信协议的设计如下图所示

定义通信过程中的Java对象

package com.example.demo.im;

import lombok.Data;

@Data
//自定义通讯协议
// 魔数(4字节)+版本号(1字节)+序列化算法(1字节)+指令(1字节)+数据长度(4字节)+数据(N字节)
public abstract class Packet {

    /**
     * 协议版本
     */
    private Byte version = 3;

    /**
     * 指令
     * @return
     */
    public abstract Byte getCmd();
}

 以客户端登录请求为例,定义登录请求数据包

package com.example.demo.im;

public interface Cmd {
    //客户端发送登录请求
    Byte LOGIN_REQUEST = 1;
    //客户端收到登录响应
    Byte LOGIN_RESPONSE = 2;
    //客户端发消息请求
    Byte MESSAGE_REQUEST = 3;
    //客户端收消息响应
    Byte MESSAGE_RESPONSE = 4;
}
package com.example.demo.im;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
//登录请求数据包
public class LoginRequestPacket extends Packet   {
    private Long userId;
    private String userName;
    private String password;

    @Override
    public Byte getCmd() {
        return Cmd.LOGIN_REQUEST;
    }
}

定义登录响应数据包

package com.example.demo.im;

import lombok.Data;

@Data
public class LoginResponsePacket extends Packet {
    //原因
    private String reason;

    //是否登录成功
    private Boolean success;

    @Override
    public Byte getCmd() {
        return Cmd.LOGIN_RESPONSE;
    }
}

定义序列化接口

package com.example.demo.im;


public interface SelfSerializable {
    /**
     * 序列化算法
     *
     * @return
     */
    byte getSerializableAlgorithm();

    /**
     * java对象转二进制数据
     *
     * @param object
     * @return
     */
    byte[] serialize(Object object);

    /**
     * 二进制转为java对象
     *
     * @param clzz
     * @param bytes
     * @param <T>
     * @return
     */
    <T> T deserialize(byte[] bytes, Class<T> clzz);

    SelfSerializable DEFAULT = new JsonSelfSerializable();
}

使用阿里的fastjson序列化

package com.example.demo.im;

public interface SerializableAlgorithm {
    /**
     * 阿里json序列化
     */
    byte ALIJSON = 1;
}
package com.example.demo.im;


import com.alibaba.fastjson.JSON;

public class JsonSelfSerializable implements SelfSerializable {
    @Override
    public byte getSerializableAlgorithm() {
        return SerializableAlgorithm.ALIJSON;
    }

    @Override
    public byte[] serialize(Object object) {
        return JSON.toJSONBytes(object);
    }

    @Override
    public <T> T deserialize( byte[] bytes,Class<T> clzz) {
        return JSON.parseObject(bytes,clzz);
    }
}

编解码

package com.example.demo.im;

import io.netty.buffer.ByteBuf;

import java.util.Objects;

// 魔数(4字节)+版本号(1字节)+序列化算法(1字节)+指令(1字节)+数据长度(4字节)+数据(N字节)
public class PacketCodec {
    public static final int MAGIC = 12345678;
    public static final PacketCodec INSTANCE = new PacketCodec();

    public void encode(ByteBuf byteBuf, Packet packet) {
        byte[] bytes = SelfSerializable.DEFAULT.serialize(packet);
        byteBuf.writeInt(MAGIC);
        
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

非ban必选

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值