午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Python socket連接中的粘包、精確傳輸問題實例分析

瀏覽:89日期:2022-08-01 13:53:27

本文實例講述了Python socket連接中的粘包、精確傳輸問題。分享給大家供大家參考,具體如下:

粘包: 發生原因:

當調用send的時候,數據并不是即時發給客戶端的。而是放到了系統的socket發送緩沖區里,等緩沖區滿了、或者數據等待超時了,數據才會發送,所以有時候發送太快的話,前一份數據還沒有傳給客戶端,那么這份數據和上一份數據一起發給客戶端的時候就會造成“粘包” 。

解決方案:

解決根源的思想是避免不同段的數據一起發送。

方案1:前一段數據send完后,等待一段時間再send第二段數據。缺點:時間效率低,而且也無法完全避免問題【因為不清楚該設置多少時間才能保證前一份數據已經發送】 方案2:握手機制:前一段數據send完后,嘗試recv,等待客戶端回應,確認第一段數據發送完后,再send第二段數據。完美方案? 方案二的演示:

服務端【發送方】代碼:

import socketserver=socket.socket()server.bind(('localhost',1234))server.listen()while True: print('正在等待。。。') conn,addr=server.accept() while True: try: conn.send(b'first info') ack=conn.recv(1024) #接收客戶端確認 print(ack) conn.send(b'second info') except ConnectionResetError as e: print(e) breakserver.close()

客戶端【接收方】代碼:

import socketclient=socket.socket()client.connect(('localhost',1234))data=client.recv(1024)print(data.decode())client.send(b'ack')#發送確認data=client.recv(1024)print(data.decode())client.close()不精確傳輸問題:發生原因:

由于數據太大,發送方一次send不完,而接收方只recv一次,使得影響了后面數據的傳輸

解決方案:

解決根源的思想是改變recv的次數。

方案:將數據的大小發給接收方,讓接收方來決定recv的次數方案實現代碼【以解決長數據shell命令傳輸為例】:

服務端【發送方】:

import socket,osserver=socket.socket()server.bind(('localhost',1234))server.listen()while True: print('正在等待...') conn,addr=server.accept() print('連接成功!') while True: try: cmd=conn.recv(1024) data=os.popen(cmd.decode()).read() # print(data) cmd_len=len(data.encode()) print(cmd_len) #發現這里如果cmd_len為0會導致異常,有些是沒有返回值的command if cmd_len==0:data='command has nothing return'cmd_len=len(data.encode()) ##因為這里前面沒有發送操作,所以不用擔心粘包,如果有則要考慮處理 conn.send(str(cmd_len).encode())#因為len結果是int,所以還要轉換 #這里要處理粘包 ack=conn.recv(1024) conn.send(data.encode()) except ConnectionResetError as e: print(e) breakserver.close()

客戶端【接收方】:

import socketclient=socket.socket()client.connect(('localhost',1234))while True: cmd = input('>>:') client.send(cmd.encode()) data_len=client.recv(1024) data_len=int(data_len.decode()) print(data_len) recv_len=0 client.send(b’ack’) total_data=b’’ while recv_len<data_len: data=client.recv(1024) recv_len+=len(data) total_data+=data print(total_data.decode())client.close() 利用這個原理可以實現文件傳輸,只要能確定接受次數,就能保證文件傳輸的大小正確。

更多關于Python相關內容可查看本站專題:《Python Socket編程技巧總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》

希望本文所述對大家Python程序設計有所幫助。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲一区高清 | 草草视频在线观看 | 超在线视频 | 天堂av免费在线 | 鲁大师影院中文字幕 | 国产精品揄拍一区二区 | 日本一区二区精品 | 一级片一级片 | 成年人免费观看视频网站 | 91首页| 18禁毛片 | 精品国产免费人成在线观看 | 亚洲三级av | 欧美福利在线观看 | 国产一区二区三区高清 | 人人爽爽爽 | 四虎影院国产精品 | 国产精品久久久久久av | 国产精品久久久久久中文字 | 少妇特黄一区二区三区 | 亚洲a在线观看 | 69天堂网 | 在线视频一区二区三区 | 一二三区在线观看 | 自拍偷拍中文字幕 | 蜜桃av噜噜一区二区三区 | 四虎影院在线免费 | 国产成人精品免高潮在线观看 | 国产第3页 | 国产91亚洲 | 日韩三级一区二区三区 | 中文字幕第一页亚洲 | 亚洲天堂国产 | 亚洲爱爱网 | 中文字幕6| 亚洲视频精品 | 国产精品久久久久久久久久久久久 | 超碰人人人人人人人 | 欧美日韩乱码 | 一级做a爱片久久毛片 | 日韩黄网 |