這期內容當中小編將會給大家帶來有關怎么在Python中使用socket實現一個通信功能,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
常用的地址家族
AF_UNIX:基于文件,實現同一主機不同進程之間的通信
AF_INET:基于網絡,適用于IPv4
AF_INET6:基于網絡,使用于IPv6
常見的連接類型
SOCK_STREAM:即TCP/IP。面向連接的套接字,通信之前必須建立可靠的連接。面向連接的套接字提供序列化的、可靠的和不重復的數據交付,而沒有記錄邊界。
SOCK_DGRAM:即UDP。面向非連接的套接字,通信之前無需建立連接。在數據傳輸過程中無法保證數據的有序性、可靠性和重復性。然而數據報確實保存了記錄邊界,意味著數據是以整體發送的,而非事先切割多個片段。
socket通信
server端
import socket server = socket.socket() # 默認是AF_INET、SOCK_STREAM server.bind(("localhost",6868)) # 將主機號與端口綁定到套接字 server.listen() # 設置并啟動TCP監聽器 while True: conn,addr = server.accept() # 被動接受TCP連接,一直等待連接到達 while True: data = conn.recv(1024) # 接收TCP消息,并制定最大長度 if not data: print("連接已斷開") break conn.send(data.upper()) # 將接收到的數據轉為大寫在發回給它 server.close()
client端
import socket client = socket.socket() # 默認是AF_INET、SOCK_STREAM client.connect(("localhost",6868)) while True: s = input(">>") client.send(s.encode("utf-8")) data = client.recv(1024) client.close()
執行結果:
socketserver模塊
使用socketserver實現多并發
import socketserver class MyServer(socketserver.BaseRequestHandler): def handle(self): while True: self.data = self.request.recv(1024) if not self.data: print("%s客戶端連接已斷開"%self.client_address) break self.request.sendall(self.data.upper()) if __name__ == "__main__": server = socketserver.ThreadingTCPServer(("localhost",6969),MyServer) # 開啟一個線程 server.serve_forever()
上述就是小編為大家分享的怎么在Python中使用socket實現一個通信功能了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。