应用层通信报文设计

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

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

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

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

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

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

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

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

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

相关推荐
gadiaola4 小时前
【计算机网络面试篇】HTTP
java·后端·网络协议·计算机网络·http·面试
报错小能手5 小时前
计算机网络自顶向下方法57——网络安全 基础与密码学原理
计算机网络·安全·web安全
百***81276 小时前
《计算机网络》(B)复习
网络·计算机网络
报错小能手7 小时前
计算机网络自顶向下方法50——链路层 虚拟局域网 链路虚拟化:网络作为链路层(多协议标签交换)
网络·计算机网络·智能路由器
报错小能手7 小时前
计算机网络自顶向下方法60——网络安全 详解TLS(传输层安全协议)
计算机网络·安全·web安全
报错小能手8 小时前
计算机网络自顶向下方法55——无线网移动网 移动性管理
网络·计算机网络
搞科研的小刘选手13 小时前
【厦门大学主办】第六届计算机科学与管理科技国际学术会议(ICCSMT 2025)
人工智能·科技·计算机网络·计算机·云计算·学术会议
甄心爱学习16 小时前
计算机网络13
计算机网络·ip协议
神仙别闹16 小时前
《计算机网络》课程实验
计算机网络
ROCKY_8171 天前
计算机网络考试考点——概述
计算机网络