主頁 > 知識(shí)庫 > python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)

python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)

熱門標(biāo)簽:北京電信外呼系統(tǒng)靠譜嗎 大連crm外呼系統(tǒng) 洪澤縣地圖標(biāo)注 老人電話機(jī)器人 高德地圖標(biāo)注是免費(fèi)的嗎 地圖標(biāo)注視頻廣告 梅州外呼業(yè)務(wù)系統(tǒng) 無錫客服外呼系統(tǒng)一般多少錢 百度地圖標(biāo)注位置怎么修改

1,七層網(wǎng)絡(luò)協(xié)議

應(yīng)表會(huì)傳網(wǎng)數(shù)物:

應(yīng)用層、表示層、會(huì)話層: (這三層又可以合并為應(yīng)用層,這樣就是五層網(wǎng)絡(luò)協(xié)議【osi五層協(xié)議】) python '你好'.encoding('utf-8')

傳輸層: 預(yù)備如何傳輸、使用的端口 (port,tcp,udp); 四層路由器、四層交換機(jī)

網(wǎng)絡(luò)層: ip(ipv4 ipv6); 路由器、三層交換機(jī)

數(shù)據(jù)鏈路層: mac(mac, arp協(xié)議:可以通過ip找到mac); 二層交換機(jī)、網(wǎng)卡(單播、廣播、組播,arp用到單播和廣播)

物理層 : 轉(zhuǎn)成電信號(hào)

2,TCP/UDP

tcp需要先建立連接,然后才能夠通信(類似于打電話)

  • 占用連接,可靠(消息不會(huì)丟失),實(shí)時(shí)性高,慢(效率低、面向連接、可靠、全雙工)
  • 三次握手
    • 客戶端向服務(wù)器端發(fā)送syn請(qǐng)求
    • 服務(wù)端回復(fù)ack并發(fā)送syn請(qǐng)求
    • 客戶端接收到請(qǐng)求后再回復(fù)ack,連接建立
      • 在socket中是由 客戶端connect() 和 服務(wù)端accept()兩個(gè)命令完成的
  • 四次揮手
    • 客戶端向服務(wù)端發(fā)送fin請(qǐng)求
    • 服務(wù)端回復(fù)ack確認(rèn)
    • 服務(wù)端向客戶端發(fā)送fin請(qǐng)求
    • 客戶端回復(fù)ack確認(rèn)
      • 在socket中是由 客戶端sk.close() 和 服務(wù)端 conn.close()兩個(gè)命令完成的
      • 揮手時(shí)服務(wù)端的ack和fin不能同時(shí)發(fā)送,因?yàn)榭蛻舳税l(fā)送完所有信息時(shí),服務(wù)端不一定完成了所有信息的發(fā)送

udp不需要建立連接,就可以通信(類似于發(fā)信息)

不占用連接,不夠可靠(消息因?yàn)榫W(wǎng)絡(luò)不穩(wěn)定可能丟失),實(shí)時(shí)性不高(效率高、無連接的、不可靠的)

3,例子

'''
------------------------------
TCP協(xié)議
------------------------------
'''
'''server'''
import socket

sk = socket.socket()
sk.bind(('127.0.0.1', 6000))
sk.listen()

conn, addr = sk.accept()
conn.send('你好'.encode('utf-8'))
msg = conn.recv(1024)
print(msg.decode('utf-8'))
conn.close()

sk.close()

'''client'''
import socket

sk = socket.socket()
sk.connect(('127.0.0.1', 6000))

msg = sk.recv(1024)
print(msg.decode('utf-8'))
sk.send('再見'.encode('utf-8'))

sk.close()

'''
------------------------------
UDP協(xié)議
------------------------------
'''
'''server'''
import socket

sk = socket.socket(type=socket.SOCK_DGRAM)   #SOCK_DGRAM udp    default tcp
sk.bind(('127.0.0.1', 6000))

# msg = sk.recv(1024)
# print(msg.decode('utf-8'))

while True:
    msg = sk.recvfrom(1024)
    print(msg)
    print(msg[0].decode('utf-8'))
    if msg[0].decode('utf-8') == '對(duì)方和你斷開了連接':
        continue
    msgSend = input('>>>')
    sk.sendto(msgSend.encode('utf-8'), msg[1])

'''client'''
import socket

sk = socket.socket(type=socket.SOCK_DGRAM)
server = ('127.0.0.1', 6000)

while True:
    msgSend = input('>>>')
    if msgSend.upper() == 'Q':
        sk.sendto('對(duì)方和你斷開了連接'.encode('utf-8'), server)
        break
    sk.sendto(msgSend.encode('utf-8'), server)
    msg = sk.recv(1024).decode('utf-8')
    if msg.upper() == 'Q':
        print('對(duì)方和你斷開了連接')
        break
    print(msg)

4,粘包

只出現(xiàn)在tcp協(xié)議中,因?yàn)閠cp協(xié)議中多條消息之間沒有邊界,并且還有各種優(yōu)化算法,因此會(huì)導(dǎo)致發(fā)送端和接收端都存在粘包現(xiàn)象:

發(fā)送端:兩條消息很短,而且發(fā)送的間隔時(shí)間也很短

接收端:多條消息沒有及時(shí)接收,而在接收方的緩存堆在一起導(dǎo)致粘包

'''server'''
import socket

sk = socket.socket()
sk.bind(('127.0.0.1', 6000))
sk.listen()

conn, addr = sk.accept()
conn.send(b'hello')
conn.send(b'byebye')

conn.close()
sk.close()

'''client'''
import time
import socket

sk = socket.socket()
sk.connect(('127.0.0.1', 6000))

time.sleep(0.1)
msg = sk.recv(5)
print(msg)
msg = sk.recv(4)
print(msg)

sk.close()

解決粘包問題的本質(zhì):設(shè)置邊界(發(fā)送長度、發(fā)送消息,交替進(jìn)行)

1,自定義協(xié)議

'''server'''
import socket

sk = socket.socket()
sk.bind(('127.0.0.1', 6000))
sk.listen()

conn, addr = sk.accept()
msg1 = input('>>>').encode('utf-8')
msg2 = input('>>>').encode('utf-8')

def sendFunc(msg):
    num = str(len(msg))
    ret = num.zfill(4)
    conn.send(ret.encode('utf-8'))
    conn.send(msg)
sendFunc(msg1)
sendFunc(msg2)

conn.close()
sk.close()

'''client'''
import socket

sk = socket.socket()
sk.connect(('127.0.0.1', 6000))

def receiveFunc():
    num = sk.recv(4).decode('utf-8')
    msg = sk.recv(int(num))
    print(msg.decode('utf-8'))

receiveFunc()
receiveFunc()

sk.close()

2,struct模塊

import struct
'''~2**32, 排除符號(hào)位,相當(dāng)于1G的數(shù)據(jù)的長度'''

num1 = 1231341234
num2 = 1342342
num3 = 12

ret1 = struct.pack('i', num1)
print(ret1)
print(len(ret1))
ret2 = struct.pack('i', num2)
print(ret2)
print(len(ret2))
ret3 = struct.pack('i', num3)
print(ret3)
print(len(ret3))

ret11 = struct.unpack('i', ret1)
print(ret11)
print(type(ret11[0]))

以上就是python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于python 網(wǎng)絡(luò)編程的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • python神經(jīng)網(wǎng)絡(luò)編程之手寫數(shù)字識(shí)別
  • Python網(wǎng)絡(luò)編程之ZeroMQ知識(shí)總結(jié)
  • python Socket網(wǎng)絡(luò)編程實(shí)現(xiàn)C/S模式和P2P
  • python神經(jīng)網(wǎng)絡(luò)編程實(shí)現(xiàn)手寫數(shù)字識(shí)別
  • python網(wǎng)絡(luò)編程:socketserver的基本使用方法實(shí)例分析
  • python網(wǎng)絡(luò)編程socket實(shí)現(xiàn)服務(wù)端、客戶端操作詳解
  • Python網(wǎng)絡(luò)編程之使用TCP方式傳輸文件操作示例
  • Python 網(wǎng)絡(luò)編程之UDP發(fā)送接收數(shù)據(jù)功能示例【基于socket套接字】
  • python網(wǎng)絡(luò)編程之多線程同時(shí)接受和發(fā)送
  • python socket網(wǎng)絡(luò)編程之粘包問題詳解

標(biāo)簽:泉州 清遠(yuǎn) 岳陽 洛陽 長春 怒江 安慶 吉林

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)》,本文關(guān)鍵詞  python,網(wǎng)絡(luò)編程,要點(diǎn),總結(jié),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于python 網(wǎng)絡(luò)編程要點(diǎn)總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章