久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python網(wǎng)絡(luò)編程調(diào)用接收數(shù)據(jù)的三種方法

Python網(wǎng)絡(luò)編程調(diào)用接收數(shù)據(jù)的三種方法

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-07 01:44:43 1699292683

最近在使用python進(jìn)行網(wǎng)絡(luò)編程開(kāi)發(fā)一個(gè)通用的tcpclient測(cè)試小工具。在使用socket進(jìn)行網(wǎng)絡(luò)編程中,如何判定對(duì)端發(fā)送一條報(bào)文是否接收完成,是進(jìn)行socket網(wǎng)絡(luò)開(kāi)發(fā)必須要考慮的一個(gè)問(wèn)題。這里,簡(jiǎn)要介紹一下判別數(shù)據(jù)接收接收完成常用的三種方法:

1.基礎(chǔ)數(shù)據(jù)接收法:

使用基礎(chǔ)數(shù)據(jù)接收法時(shí),當(dāng)與服務(wù)socket斷開(kāi)連接時(shí),會(huì)接收到空字符串。因此,可以根據(jù)此特點(diǎn),在程序中加入循環(huán),一直接收數(shù)據(jù),直到數(shù)據(jù)發(fā)送端關(guān)閉socket連接。適用場(chǎng)景:客戶端和服務(wù)器的鏈接為短鏈接(即一次socket通訊后連接就會(huì)關(guān)閉)。代碼如下:

importsocket,struct,sys,time

Port=22220

#assumeasocketdisconnect(datareturnedisemptystring)meansalldatawas#donebeingsent.

defrecv_basic(the_socket):

total_data=[]

whileTrue:

data=the_socket.recv(20480)

ifnotdata:break

total_data.append(data)

return''.join(total_data)

2.尾標(biāo)識(shí)方法

通過(guò)尋找接收的協(xié)議數(shù)據(jù)中的尾標(biāo)識(shí)字符串,獲取完整的數(shù)據(jù)的數(shù)據(jù)報(bào)文。適用場(chǎng)景:接收的協(xié)議數(shù)據(jù)中包含相關(guān)的尾標(biāo)識(shí)。代碼如下:

End='somethinguseableasanendmarker'

defrecv_end(the_socket):

total_data=[];data=''

whileTrue:

data=the_socket.recv(8192)

ifEndindata:

total_data.append(data[:data.find(End)])

break

total_data.append(data)

iflen(total_data)>1:

#checkifend_of_datawassplit

last_pair=total_data[-2]+total_data[-1]

ifEndinlast_pair:

total_data[-2]=last_pair[:last_pair.find(End)]

total_data.pop()

break

return''.join(total_data)

3.負(fù)載長(zhǎng)度方法

即通過(guò)協(xié)議數(shù)據(jù)中的負(fù)載長(zhǎng)度值,確定有效報(bào)文的長(zhǎng)度,適用場(chǎng)景:協(xié)議數(shù)據(jù)中包含負(fù)載協(xié)議字段。這種方法也是比較常用和通用的一種方法,但是需要一邊接收數(shù)據(jù)一邊解析數(shù)據(jù)。代碼如下:

defrecv_size(the_socket):

#datalengthispackedinto4bytes

total_len=0;total_data=[];size=sys.maxint

size_data=sock_data='';recv_size=8192

whiletotal_len

sock_data=the_socket.recv(recv_size)

ifnottotal_data:

iflen(sock_data)>4:

size_data+=sock_data

size=struct.unpack('>i',size_data[:4])[0]

recv_size=size

ifrecv_size>524288:recv_size=524288

total_data.append(size_data[4:])

else:

size_data+=sock_data

else:

total_data.append(sock_data)

total_len=sum([len(i)foriintotal_data])

return''.join(total_data)

以上內(nèi)容為大家介紹了Python網(wǎng)絡(luò)編程調(diào)用接收數(shù)據(jù)的三種方法,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.2667701.com/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
用 Python 高效背單詞

作為一個(gè)程序員,經(jīng)常需要閱讀英文論文、文檔、書(shū)籍。對(duì)于一些基礎(chǔ)不好的同學(xué)來(lái)說(shuō),最主要的攔路虎是英語(yǔ)單詞。計(jì)算機(jī)類文檔不同于小說(shuō),其語(yǔ)法...詳情>>

2023-11-07 04:33:56
Python處理文件的幾個(gè)常用小知識(shí)

python這門(mén)語(yǔ)言有個(gè)很大的用途就是使用它來(lái)進(jìn)行文件處理,學(xué)會(huì)處理文件和保存數(shù)據(jù)可以讓你的程序使用起來(lái)更加容易和方便,因此小編為大家準(zhǔn)備了...詳情>>

2023-11-07 03:54:20
python經(jīng)典最短代碼實(shí)現(xiàn)排序的功能

冒泡排序:算法思想:1.比較相鄰的元素,如果第一個(gè)比第二個(gè)大,則交換他們的位置;2.依次對(duì)每一對(duì)的元素進(jìn)行比較,如果前一個(gè)比后一個(gè)大,則交...詳情>>

2023-11-07 03:50:44
Python五大應(yīng)用領(lǐng)域

1、Linux運(yùn)維用python實(shí)現(xiàn)的測(cè)試工具及過(guò)程,包含服務(wù)器端、客戶端、web、andriod、client端的自動(dòng)化測(cè)試,自動(dòng)化性能測(cè)試的執(zhí)行、監(jiān)控和分析,...詳情>>

2023-11-07 03:25:32
Python與Node.JS

在進(jìn)行新項(xiàng)目時(shí)選擇正確的編程語(yǔ)言可能是程序員經(jīng)常做出的比較艱巨的決定之一。這個(gè)挑戰(zhàn)背后的原因是,每個(gè)新項(xiàng)目都會(huì)遇到一個(gè)獨(dú)特的問(wèn)題,并且...詳情>>

2023-11-07 03:14:44