Python 实现Google Protocol Buffer数据传输与转换
Server:
-- coding: utf-8 --
import socket,test_pb2
addr_confm = (‘192.168.1.35’, 12340)
#创建socket传输方式
clic = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#邦定地址
clic.bind(addr_confm)
#监听一个连接
clic.listen(1)
#接受客户端传输
cl, addr = clic.accept()
#创建一个protobuf 对像
send_message = test_pb2.people()
#设置要传输的数据与protobuf相符
send_message.name = ‘maomao’
send_message.height = 999
#print (“len=”,len(send_message.SerializeToString()))
#计算protobuf数据长度.SerializeToString()序列化需要传输的数据,计算出的长度需要转换为bytes用于传输,to_bytes(4,byteorder=‘big’)为转换为4个字节长度的大端数据
send_head = (len(send_message.SerializeToString())).to_bytes(4, byteorder=‘big’)
#传输头长度
cl.sendall(send_head)
#序列化需要传输的数据
send_data = send_message.SerializeToString()
#传输序更化后的数据
cl.sendall(send_data)
cl.close()
Client:
-- coding: utf-8 --
import socket,test_pb2
#设置需要连接的服务器地址与端口
addr_data = (‘192.168.1.35’ , 12340)
#创建data序列化对像
data = test_pb2.people()
#设置连接方式
clid = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#创建连接
clid.connect(addr_data)
#message_size = struct.Struct(data).size
#接受报文头约束报文头为4个字节故先接受4个字节判断报文长度
recv_head = clid.recv(4)
#计算接受到的4个字节转换为10进制数据,按字节的大端方式转换
data_len = int.from_bytes(recv_head, byteorder=‘big’)
print (“recv head=”,data_len)
#接收数据主体,接收长度为报文头转换后的长度
recv_data = clid.recv((data_len))
#使用序列化后的对像的ParseFromString反序列化方式,反序列化收到的数据
data.ParseFromString(recv_data)
print ("botid = " , data.name)
print ("Vel1 = " , data.height)
clid.close()