python粘包問題及socket套接字編程詳解
粘包問題
TCP協(xié)議在傳輸過程中會出現(xiàn)數(shù)據(jù)粘包問題
講一下TCP和UDP的區(qū)別,都是傳數(shù)據(jù)的協(xié)議,沒有好壞之說,只是不同的應(yīng)用需求可能會更好選擇哪一個協(xié)議
TCP:適合傳輸數(shù)量大 ,需要建立連接,會出現(xiàn)粘包問題,粘包問題可以解決,確定傳入的長度,接收同樣長度就可以保證一次性傳輸完
UDP: 適合傳輸數(shù)據(jù)量小,沒有粘包,不需要連接,一次性傳輸,下一次就是新的數(shù)據(jù),弊端就是數(shù)據(jù)丟失,不安全
QQ是用什么協(xié)議呢?按理應(yīng)該可以用UDP協(xié)議,但是實際用的是TCP協(xié)議,這是歷史遺留問題,可還記得我們輸入QQ一次性輸入的內(nèi)容字數(shù)有限制嗎?就是規(guī)定了發(fā)送與接收的數(shù)據(jù)長度是一樣的.
形成粘包的原因
1.兩個數(shù)據(jù)非常小,然后間隔時間又短
2.數(shù)據(jù)太大,一次取不完,下一次還會取這個大數(shù)據(jù)
解決粘包問題
==在傳數(shù)據(jù)之前,傳一個數(shù)據(jù)的大小,數(shù)據(jù)的大小必須得定長==
# TCP 解決粘包問題 附帶處理了一下
import socket
import struct
import subprocess
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind(('127.0.0.1', 8000))
server.listen(5)
print('start...')
# 連接循環(huán)
while True:
conn, client_address = server.accept()
print(client_address)
# 通信循環(huán)
while True:
try:
cmd = conn.recv(1024)
print(cmd)
pipeline = subprocess.Popen(cmd.decode('utf8'),
shell=True,
stderr=subprocess.PIPE,
stdout=subprocess.PIPE)
stdout = pipeline.stdout.read()
stderr = pipeline.stderr.read()
count_len = len(stdout) + len(stderr)
guding_bytes = struct.pack('i', count_len)
conn.send(guding_bytes) # 4
conn.send(stderr + stdout)
except ConnectionResetError: # 連接循環(huán)時出現(xiàn)的中斷
break
conn.close()
# 客戶端
mport struct
from socket import *
client = socket(AF_INET, SOCK_STREAM)
client.connect(('127.0.0.1', 8000))
while True:
# cmd = input('please enter your cmd you want:')
cmd = 'dir'
client.send(cmd.encode('utf8'))
guding_bytes = client.recv(4)
count_len = struct.unpack('i', guding_bytes)[0]
data = client.recv(count_len)
print(data.decode('gbk'))
基于UDP協(xié)議的socket套接字編程
UDP 無連接
# UDP服務(wù)端
import socket
server = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
server.bind(('127.0.0.1', 8000))
print('start...')
while True:
data, client_addr = server.recvfrom(1024)
print(client_addr)
print(data)
server.sendto(data.upper(), client_addr)
# UDP客戶端
import socket
client = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
while True:
msg = input('please enter your msg:')
client.sendto(msg.encode('utf8'), ('127.0.0.1', 8000))
data = client.recvfrom(1024)
print(data)
和TCP是差不多的,調(diào)用的功能是一樣的,只是方法名的具體表示方法不一樣,因為UDP無連接,UDP的sendto和TCP的send ,就是UDP的sendto要直接指到地址的
基于socketserver實現(xiàn)并發(fā)的socket套接字編程
讓服務(wù)端同時和多個客戶端進行連接,以前我們寫的是一個警局有五部電話只有一個人,現(xiàn)在寫的五部電話五個人
# 同一時刻有多個人在接聽
import socketserver
import subprocess
import struct
class MyHandler(socketserver.BaseRequestHandler):
# 通信循環(huán)
def handle(self):
while True:
try:
cmd = self.request.recv(1024)
print(cmd)
pipeline = subprocess.Popen(cmd.decode('utf8'),
shell = True,
stderr = subprocess.PIPE,
stdout = subprocess.PIPE)
stdout = pipeline.stdout.read()
stderr = pipeline.stderr.read()
count_len = len(stderr) + len(stdout)
guding_bytes = struct.pack('i', count_len)
self.request.send(guding_bytes) # 4
self.request.send(stderr + stdout)
except ConnectionResetError:
break
# 使用socketserver的連接循環(huán)(并發(fā)),但是使用了自己的通信循環(huán)
# myhandler = MyHandler()
if __name__ == '__main__':
server = socketserver.ThreadingTCPServer(('127.0.0.1', 8000), MyHandler, bind_and_activate=True)
print('start...')
server.serve_forever()
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python操作docx寫入內(nèi)容,并控制文本的字體顏色
今天小編就為大家分享一篇python操作docx寫入內(nèi)容,并控制文本的字體顏色,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
Python的math模塊中的常用數(shù)學函數(shù)整理
這篇文章主要介紹了Python的math模塊中的常用數(shù)學函數(shù)整理,同時對運算符的運算優(yōu)先級作了一個羅列,需要的朋友可以參考下2016-02-02
用Python的Django框架完成視頻處理任務(wù)的教程
這篇文章主要介紹了用Python的Django框架完成視頻處理任務(wù)的教程,包括用戶的視頻上傳和播放以及下載功能的實現(xiàn),需要的朋友可以參考下2015-04-04
Python+SeaTable實現(xiàn)生成條形碼圖片并寫入表格
不管是錄入信息時需要用掃碼器掃碼錄入,還是有別的生成條形碼的需要,這在?SeaTable?表格中用?Python?腳本就可以輕松實現(xiàn),本文就來為大家詳細講解一下2022-07-07
Python 實現(xiàn)反轉(zhuǎn)整數(shù)的案例(很容易懂的那種)
這篇文章主要介紹了Python 實現(xiàn)反轉(zhuǎn)整數(shù)的案例(很容易懂的那種),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03
python使用aiohttp通過設(shè)置代理爬取基金數(shù)據(jù)簡單示例
這篇文章主要為大家介紹了python使用aiohttp通過設(shè)置代理爬取基金數(shù)據(jù)簡單示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06
tensorflow estimator 使用hook實現(xiàn)finetune方式
今天小編就為大家分享一篇tensorflow estimator 使用hook實現(xiàn)finetune方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01

