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获取指定长度的消息,确保信息没有遗漏。

 

原创文章,作者:bd101bd101,如若转载,请注明出处:https://blog.ytso.com/275566.html

(0)
上一篇 2022年7月20日
下一篇 2022年7月20日

相关推荐

发表回复

登录后才能评论