python基礎-網路編程part02

来源:https://www.cnblogs.com/xiaodan1040/archive/2019/12/05/11991637.html
-Advertisement-
Play Games

TCP協議 TCP是傳輸控制協議,建立雙向通道。 三次握手,建立連接 客戶端向服務端發送建立連接的請求 服務端接收請求返回確認信息給客戶端,並向客戶端發送建立連接的請求 客戶端接收請求返回確認信息給服務端 反饋機制: 一次請求必須有一次響應 。即收到請求後,必須告知對方已收到請求。 四次揮手,斷開連 ...


TCP協議

TCP是傳輸控制協議,建立雙向通道。

三次握手,建立連接

  • 客戶端向服務端發送建立連接的請求
  • 服務端接收請求返回確認信息給客戶端,並向客戶端發送建立連接的請求
  • 客戶端接收請求返回確認信息給服務端

反饋機制:一次請求必須有一次響應。即收到請求後,必須告知對方已收到請求。

四次揮手,斷開連接

  • 客戶端向服務端發送斷開連接的請求
  • 服務端接收請求返回確認信息發給客戶端
  • 服務端確認所有數據接收完畢以後,發送斷開連接的請求給客戶端
  • 客戶端接收請求返回確認信息給服務端

socket套接字通信

定義:python內置的模塊,又稱套接字,用來封裝互聯網協議(應用層以下的層)

作用:實現互聯網協議應用層以下的工作,提高開發效率

使用方式:見代碼

  • 服務端server.py
import socket

# 獲取socket 對象
server = socket.socket()
# 綁定服務端ip 地址和埠
# 127.0.0.1是迴環地址,表示本機ip
server.bind(('127.0.0.1', 8080))
# 半連接池,表示可以同時讓多少個客戶端訪問。
# 一個客戶端正在交互,剩下的等待交互,listen(n):n+1個客戶端
server.listen(5)
# 阻塞,直到客戶端訪問,返回連接請求和客戶端IP
conn, client = server.accept()
# 接收客戶端發送的信息並列印
# 接收預設最大位元組數:1024(可根據記憶體自行調整)
client_data = conn.recv(1024).decode('utf-8')
print(f"來自客戶端的消息:{client_data}")
# 向客戶端發送消息
send_msg = input("請輸入指令>>>>>:").strip().encode('utf-8')
conn.send(send_msg)

# 關閉連接
conn.close()
# 關閉服務
server.close()
  • 客戶端client.py
import socket

# 創建socket對象
client = socket.socket()
# 向服務端請求連接
client.connect(('127.0.0.1', 9527))
# 向服務端發送數據,send只接收二進位數據
client_msg = input("請輸入要發送給服務端的信息>>>>:").strip()
client.send(client_msg.encode('utf-8'))
# 接收服務端返回的數據
# 接收預設最大位元組數:1024(可根據記憶體自行調整)
client_data = client.recv(1024).decode('utf-8')
print(f"來自服務端的消息:{client_data}")
# 關閉連接
client.close()

註意:

  • 先啟動服務端,再啟動客戶端
  • 一次數據請求必須有一次響應,服務端和客戶端不能同時發送請求或同時接收請求

粘包現象

  • 現象一:數據多次發送時間間隔短,且量少時,接送一次讀取了信息,後續讀取記錄為空
# 客戶端.py
import socket

server = socket.socket()
server.connect(("127.0.0.1", 9527))

# 連續發送
server.send(b"hello")
server.send(b"hello")
server.send(b"hello")

server.close()
# 服務端.py
import socket
from socket import SOL_SOCKET
from socket import SO_REUSEADDR

server = socket.socket()
server.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
server.bind(("127.0.0.1", 9527))
server.listen(5)
conn, client = server.accept()

data1 = conn.recv(1024)
data2 = conn.recv(1024)
data3 = conn.recv(1024)

print(data1)
print(data2)
print(data3)

conn.close()
server.close()

輸出結果

b'hellohellohello'
b''
b''
  • 現象二:當發送數據的位元組數超出每次接收的最大限制數,會將上次沒有接收完的記錄在下次接收
# 客戶端.py
import socket

client = socket.socket()
client.connect(('127.0.0.1', 9527))
client.send(b'hello world!')
client.send(b'lift is smart!')
client.close()
# 服務端.py
import socket
from socket import SOL_SOCKET
from socket import SO_REUSEADDR

server = socket.socket()
server.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
server.bind(('127.0.0.1', 9527))
server.listen(5)

conn, client = server.accept()

re_data1 = conn.recv(5).decode('utf-8')
re_data2 = conn.recv(5).decode('utf-8')

print(re_data1)
print(re_data2)
conn.close()
server.close()

輸出結果

hello
 worl

struct模塊—解決粘包問題

定義:python內置的模塊,可以將 固定長度的數據,打包成固定格式的長度

作用:將真實數據,做成一個固定長度的報頭,客戶端發送給服務端,服務端可以接收報頭(反之亦然)。然後對報頭進行解包,獲取真實數據的長度,進行接收即可。

使用,以現象二舉例(實質都一樣解決)

# 客戶端.py
import socket
import struct

client = socket.socket()
client.connect(('127.0.0.1', 9527))
msg1 = 'hello world!'
# 使用struct模塊中的pack方法,模式‘i’表示4個位元組
# 將要發送的數據長度打包成一個header
header1 = struct.pack('i', len(msg1))
# 先將報頭髮送給服務端
client.send(header1)
# 再將真實數據發送給服務端
client.send(msg1.encode('utf-8'))
# 服務端.py
import socket
import struct

server = socket.socket()
server.bind(('127.0.0.1', 9527))
server.listen(5)
conn, client = server.accept()

# 讀取報頭
header = conn.recv(4)
# 使用struct.unpack 解析真實數據長度
header_len = struct.unpack('i', header)[0]

# 讀取真實數據
re_data = conn.recv(header_len)

print(re_data.decode('utf-8'))
conn.close()
server.close()

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、GC 第一步:判斷對象是否已死?有兩種方法:第一種是引用計數法,即給對象添加一個引用計數器,當被引用時,計數器就+1;當引用失效時,就-1;當計數器為0時,代表對象沒有被引用。但是計數器的缺點就是:對象之間相互引用時導致計數器不為零,無法被回收。第二種方法是可達性分析法,即通過定義一系列的GC ...
  • 解決方法 方法一:換一個埠 若仍然想要使用該埠,則可以將占用該埠的進程殺死即可。 方法二:殺死占用該埠的進程 若仍然想要使用該埠,則可以將占用該埠的進程殺死即可 查找埠被占用的進程id netstat -nao | findstr “埠號” 查詢埠號對應的進程 tasklist | ...
  • 想象一下,程式員沒有WIFI會怎樣? 程式員沒有網路肯定會寸步難行! 但是對於Python程式員來說,只要附近有熱點,分分鐘就能蹭網成功! 想要WIFI破解,python+字典,這是必少不了的。熱點加弱口令也是核心。字典自己加精,你的字典有強大,你能破解的WIFI就越多,提供兩種方法,一般人學到一種 ...
  • 1.os.path.exists()既可以判斷文件是否存在,又可以判斷文件夾是否存在 2.os.path.isfile()判斷文件是否存在 3.os.path.isdir()判斷文件夾是否存在 ...
  • 前言 這篇文章主要是從pinpoint web界面入手,我們的目標是弄清楚兩個問題: 1、 pinpoint左側服務地圖上的調用量數據是怎麼查詢的? 2、界面查詢條件WasOnly是什麼意思? 左側服務地圖調用量來源 從下圖可以看出,A顯示被USER調用299次,線上數值代表著調用量。 我們F12跟 ...
  • 元組 元組是一個輕量級集合,這個集合可以存儲任意元素 元組是使用小括弧,元素之間使用逗號分隔,元素的類型是任意的 若需要訪問元組中的元素 [元組名._數字] 數字是從1開始, 有多少個元素,這個1遞增多少次 例如: 有一個元組,元組中有三個元素 訪問每一個元素值 --> _1 _2 _3 元組屬於輕 ...
  • 網路編程tcp協議與socket以及單例的補充 一、單例補充 實現單列的幾種方式 二、tcp協議以及粘包問題 理論知識 三、socket套接字 socket套接字初級版本 演示 socket套接字升級版本 socket套接字高級版本 socket套接字終級版本 四、粘包問題 粘包問題的出現以及幾種情 ...
  • GC分類 針對HotSpot VM的實現,它裡面的GC其實準確分類只有兩大種: Partial GC:並不收集整個GC堆的模式 Young GC:只收集young gen的GC Old GC:只收集old gen的GC。只有CMS的concurrent collection是這個模式 Mixed G ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...