应用层通信报文设计

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

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

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

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

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

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

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

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

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

相关推荐
DARLING Zero two♡1 天前
【计算机网络】简学深悟启示录:http
网络协议·计算机网络·http
梁辰兴1 天前
计算机网络基础:传输控制协议 TCP
tcp/ip·计算机网络·计算机·tcp·计算机网络基础·梁辰兴·传输控制协议
小李独爱秋1 天前
计算机网络经典问题透视:手机通过Wi-Fi接入到互联网是没有流量因而是免费的吗?
服务器·计算机网络·智能手机·信息与通信·无线网络
今儿敲了吗1 天前
计算机网络第四章笔记(四)
笔记·计算机网络
charlotte102410241 天前
计算机网络体系结构:从0到1帮你理解计算机网络体系结构!
计算机网络
junnhwan2 天前
【计算机网络-CS168-textbook阅读笔记】传输层原理与TCP设计
笔记·计算机网络·tcp·cs168
梁辰兴2 天前
计算机网络基础:用户数据报协议 UDP
网络·网络协议·计算机网络·udp·用户数据报协议·计算机网络基础·梁辰兴
醒醒酒2 天前
sqli-labs Less1-4 新手修仙版
数据库·计算机网络·安全·web安全·网络安全·oracle
今儿敲了吗2 天前
计算机网络第四章笔记(三)
笔记·计算机网络
梁辰兴3 天前
计算机网络基础:传输层的端口
网络·计算机网络·计算机·端口·传输层·计算机网络基础·梁辰兴