socket发送和接受tcp信息包格式的定义

下面为信息包的格式和内容

数据包格式如下图所示,所包含的内容从左到右进行传输:包头中的信息全部为网络字节顺序!

序号

字段名称

长度(Bytes)

类型(C++)

字段说明

1

head

2

Unsigned Short

包头标识,固定为0xFFFF

2

version

2

Unsigned Short

版本信息,当前为0x0030

3

length

2

Unsigned Short

包括包头的全部包体长度

4

command

2

Unsigned Short

命令号

5

status

4

Unsigned Integer

应答状态

6

taskid

4

Unsigned Integer

任务流水号

7

sender

4

Unsigned Integer

发送方标识1

8

sessionid

4

Unsigned Integer

发送方标识2

9

timestamp

4

Unsigned Integer

时间戳

10

flag

2

Unsigned Short

数据加密标志:0:不加密,1:DES加密

11

reserved

4

Unsigned Integer

保留字段

包头信息中,开始标识(head),版本信息(version)为固定格式;

包体长度(length),提示整个包体(包括包头)的长度,接收方据此来完成一个业务数据包的接收和解析;

命令号(command),为客户端和服务器约定的业务命令,从0到65535,具体定义详见下表:

号码段  

起始编号

结束编号

使用说明

1

0X0000

0X03E7

对应具体的业务命令号,如1为充值等

2

0X03E8

0XFFFF

系统保留命令字,目前0XFFFE为心跳包,0XFFFF为心跳应答包

 

应答状态(status),请求时总设置为0;应答时,由SP应用服务程序返回相应的操作结果或错误原因;

任务流水号(taskid)由自行定义,SP应用程序在响应包中必须返回,SP应用程序可以将此作为数据包一段时间内的唯一序列号。

发送方标识1(sender)、发送方标识2(sessionid)、时间戳(timestamp)以及保留字段(reserved),可以为发送方保留一些私有信息,返回包时原样返回。

包头信息中,除了包体长度(length)以外,其他的字段,包括开始标识(head),版本信息(version),任务流水号(taskid),发送方标识1(sender),发送方标识2(sessionid),时间戳(timestamp),以及数据加密标识(flag),需要在响应包中原样返回;
 
流程

1、 通用网关在连接建立之后,根据刚才加密的字节流,加上信息包头,组合成信息包,然后发送(Send)信息包,发送的字节数为加密后的字节流字节数+24(24信息包头的字节长度);在上述的例子中,信息包大约如ffff0200 00001100 00004e5f 00114b3f 00000000 0100 0038 2fd65329e2770074791503c2dab1d209fe0225636dd07f7277bd291209e1a498df28f7af2f0eb4f1be2831f0fa8987b7f9;其中业务加密字节流的长度这里是56,体现在网络字节中是0x0038,如果是x86系列的PC,需要做主机到网络(ntohs)字节顺序转换;

 

2、SP应用服务程序接收(Recv)该信息包,根据包头信息截取对应的字节流,然后进行解密处理,得到加密前的业务字符串,另外还需要把其他的包头标识、两个包头保留字,存储在本地;

 

3、 SP应用服务程序根据流程开发人员与之协商好的格式对接收的字符串进行解析,然后进行响应的处理

 

4、 SP应用服务程序在发送之前,同样根据密匙对该返回字符串进行加密处理,然后对加密字节流长度进行计算,加上刚才发送过来的包头标识和版本号以及保留字等,组合成信息包;注意这时,字节流的长度是返回加密字节流的长度,而且是网络字节的。

 

来自:http://blog.sina.com.cn/s/blog_62fd44430100v727.html

你可能感兴趣的:(socket)