我正在尝试解码通过TCP连接接收到的数据。数据包很小,不超过100字节。然而,当它们很多的时候,我会收到一些连接在一起的包。有没有办法防止这种情况发生?我用的是蟒蛇
我已经尝试分离数据包,我的来源在下面。数据包以stx字节开始,以etx字节结束,stx后面的字节是数据包长度(小于5的数据包长度无效),校验和是etx之前的最后一个字节。
def decode(data):
while True:
start = data.find(STX)
if start == -1: #no stx in message
pkt = ''
data = ''
break
#stx found , next byte is the length
pktlen = ord(data[1])
#check message ends in ETX (pktken -1) or checksum invalid
if pktlen < 5 or data[pktlen-1] != ETX or checksum_valid(data[start:pktlen]) == False:
print "Invalid Pkt"
data = data[start+1:]
continue
else:
pkt = data[start:pktlen]
data = data[pktlen:]
break
return data , pkt
我就是这样用的
#process reports
try:
data = sock.recv(256)
except: continue
else:
while data:
data, pkt = decode(data)
if pkt:
process(pkt)
另外,如果数据流中有多个数据包,最好将这些数据包作为列表的集合返回,还是只返回第一个数据包
我不太熟悉python,只有c,这个方法可以吗?任何建议都将是最受欢迎的。提前谢谢
谢谢