python基础 -- tcp、udp模式
2022/7/20 9:19:27
本文主要是介绍python基础 -- tcp、udp模式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
# tcp 协议服务端 import socket sk = socket.socket() #创建socket对象 sk.bind(('127.0.0.1', 8889)) #绑定socket的ip和端口 sk.listen(5) #设置socket对象的监听数量 conn, info = sk.accept() #socket开始监听连接,一直到有请求连接,这里完成三次握手,病返回连接对象,以及请求信息 conn.send(b"hello,wrold") #网络传输的数据格式是byte 类型,发送数据的格式要转化为byte类型 msg = sk.recv() #接受数据也是同样的byte类型,需要解码 print(msg.decode("utf-8")) conn.close() #表示当前连接终止,这里开始四次挥手 sk.close() #这里socket对象关闭,表示socket服务终止
#tcp客户端 import socket sk = socket.socket() sk.connect(("127.0.0.1", 8889)) sk.send(b"hualala") msg= sk.recv(1024) #这里代表一次性接收多少个数量的字节 print(msg.decode("utf-8")) sk.close()
# upd协议服务端 import socket sk = socket.socket(type=socket.SOCK_DGRAM) sk.bind(('127.0.0.1', 8889)) msg, info = sk.recvfrom(1024) print(msg) ret = sk.sendto(b'hahah', info) print(ret)
# udp服务客户端 import socket sk = socket.socket(type=socket.SOCK_DGRAM) msg= sk.sendto(b'holy, shit', ('127.0.0.1', 8889)) print(msg) msg2 = sk.recvfrom(1024) print(msg2)
2.tcp的粘包问题
问题现象:发送端将两次发送的消息一次发出,导致信息出错。
问题原因: tcp协议的机制导致。有两种情况,一种情况是发送端的合包机制,如果发送的数据量不大,并且发送时间特别接近的话,发送端会将两条信息一并发送,并接受一次返回确认。另一种情况就是,接收端的缓存机制,如果接受端没有及时接受信息,接收端会将发送来的信息缓存在内存中,按照接收端recv(长度),来取值,可能会造成数据的错误。
解决方法:指定自己的传送协议
每次发送信息,发送两次,第一次发一个指定长度的字节,表示即将发送的数据的长度,第二次才发送消息。 接受端接受两次,第一次recv指定长度的字节,解码获取消息的长度,第二次recv获取指定长度的消息,确保信息没有遗漏。
这篇关于python基础 -- tcp、udp模式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-08有遇到过吗?同样的规则 Excel 中 比Python 结果大
- 2024-03-30开始python成长之路
- 2024-03-29python optparse
- 2024-03-29python map 函数
- 2024-03-20invalid format specifier python
- 2024-03-18pool.map python
- 2024-03-18threads in python
- 2024-03-14python Ai 应用开发基础训练,字符串,字典,文件
- 2024-03-13id3 algorithm python
- 2024-03-13sum array elements python