应用层通信报文设计

复制代码
/*
+---------------------------------------------------------------+
| 魔数 2byte | 协议版本号 1byte | 序列化算法 1byte | 报文类型 1byte  |
+---------------------------------------------------------------+
| 状态 1byte |        保留字段 4byte     |      数据长度 4byte     | 
+---------------------------------------------------------------+
|                   数据内容 (长度不定)          | 校验字段 2byte |
+---------------------------------------------------------------+
*/
协议框架

1、魔数: 通信双方协商 的一个暗号 ,通常采用固定的几个字节表示。魔数的作用是用于服务端在接收数据时先解析出前几个固定字节做正确性对比。

2、协议版本号 :应对业务需求的变化,可能需要对自定义协议的结构或字段进行改动。不同版本的协议对应的解析方法也是不同的。

3、序列化算法:序列化算法字段表示发送仿将对象转换成二进制流,以及接收方接受的二进制流准换成对象的方法。最常见的是,先构造文件流对象,选择二进制读取方法,将使用read()将文件对象读入string和vector<char>中,json和Hessian,java自带序列化。

**4、报文类型:**初始化请求,初始化确认响应,文件数据块,数据块接受确认,文件传输完成通知,传输完成确认,错误通知。

5、长度域字段 :长度域字段代表请求数据的长度 ,可以定义整个报文的长度,也可以是请求数据部分的长度,

6、请求数据:请求数据业务对象信息序列化后的二进制。是整个报文的柱体。

7、状态:状态字段用于表示请求是否正常,一般有被调用方设置。例如一次RPC调用失败,状态字段可被服务提供方设置为异常状态。

8、校验字段 :校验字段存放某种校验算法计算报文校验码,校验码用于验证报文的正确性

相关推荐
Heorine15 小时前
408 计算机网络 知识点记忆(8)
计算机网络·考研
左灯右行的爱情20 小时前
计算机网络-TCP可靠传输机制
网络·tcp/ip·计算机网络
秋名RG2 天前
计算机网络起源
服务器·网络·计算机网络
编程老菜鸡2 天前
计算机网络笔记-分组交换网中的时延
笔记·计算机网络·智能路由器
Heorine2 天前
408 计算机网络 知识点记忆(6)
计算机网络·考研
噗噗bug2 天前
计算机网络 3-2 数据链路层(流量控制与可靠传输机制)
网络·计算机网络
城里有一颗星星3 天前
计算机网络(1)
计算机网络
阿威昂3 天前
计算机网络——传输层(Udp)
网络协议·计算机网络·udp
Heorine3 天前
408 计算机网络 知识点记忆(4)
计算机网络·考研