时间:2021-05-22
这篇文章主要介绍了python3 tcp的粘包现象和解决办法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
服务器端
import socketsk = socket.socket()sk.bind(("127.0.0.1", 6666))sk.listen()conn, address = sk.accept()def my_send(msg): bs = msg.encode("utf-8") len_str = format(len(bs), "04d") # 定长4位 conn.send(len_str.encode("utf-8")) conn.send(bs)my_send(input(">>>:").strip())my_send(input(">>>:").strip())客户端
import socketimport timesk = socket.socket()sk.connect(("127.0.0.1", 6666))time.sleep(10) # 制造粘包情况msg = sk.recv(1024).decode("utf-8") # 粘包现象print(msg)执行结果:
0004aaaa0003bbb有粘包的现象。
解决粘包,客户端代码调整
import socketimport timesk = socket.socket()sk.connect(("127.0.0.1", 6666))time.sleep(10)def my_recv(): len_str = int(sk.recv(4).decode("utf-8")) msg = sk.recv(len_str) print(f"来自服务端的消息:{msg.decode('utf-8')}")my_recv()my_recv()执行结果:
来自服务端的消息:aaaa来自服务端的消息:bbb以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
TCP协议中的粘包问题1.粘包现象基于TCP实现一个简易远程cmd功能#服务端importsocketimportsubprocesssever=socket.
1、error:command‘x86_64-linux-gnu-gcc'failedwithexitstatus解决办法:#Python3$sudoapt-g
一、TCP粘包产生的原理1.TCP粘包是指发送方发送的若干包数据到接收方接收时粘成一包,从接收缓冲区看,后一包数据的头紧接着前一包数据的尾。出现粘包现象的原因是
异常:python3的xadmin主题只显示默认和bootstrap2解决办法:慢慢来相信能遇到这个问题的人,都是已经配置好xadmin的,该True的也都写过
前言什么是TCP粘包问题以及为什么会产生TCP粘包,本文不加讨论。本文使用golang的bufio.Scanner来实现自定义协议解包。下面话不多说了,来一起看