应用层通信报文设计

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

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

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

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

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

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

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

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

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

相关推荐
白中白121385 天前
计算机网络系列-1
计算机网络
G皮T6 天前
【计算机网络】网络时间协议 NTP(二):X-Request-Start
网络·计算机网络·时钟同步·ntp·网络时间协议
G皮T6 天前
【计算机网络】网络时间协议 NTP(一)
网络·计算机网络·时钟同步·ntp·网络时间协议
大地的一角7 天前
(计算机网络)网络基础
计算机网络
tobias.b7 天前
408真题解析-2010-40-计算机网络-域名解析
网络·计算机网络·计算机考研·408真题解析
EmmaXLZHONG8 天前
分布式系统概念与设计笔记(Notes of Distributed Systems Concepts and Design)
笔记·分布式·网络协议·计算机网络
林姜泽樾8 天前
linux基础第一章,linux的介绍和它和windows的区别
linux·运维·计算机网络·安全·网络安全
wangjialelele8 天前
万字整理计算机网络知识点
linux·c语言·网络·c++·计算机网络·php
REDcker9 天前
FTP协议原理及应用精解
linux·后端·计算机网络·互联网·ftp·服务端开发
8125035339 天前
DNS监控:生产实践
linux·网络·网络协议·tcp/ip·计算机网络