python socket函數詳解


python socket函數詳解

學習了部分有關python socket函數方面的編程操作,但是對於socket函數的了解知之甚少,許多函數在用的時候,都需要在借助網上資料,浪費很多的時間,索性花費一點功夫整理一番,好方便自己以后查閱。

主要介紹:socket、bind、listen、connect、accept、send、sendto、recv、recvfrom、close、shutdown。

一、socket類型

套接字格式

socket(family,type[,protocal])使用給定的地址族,套接字類型,協議編號(默認為0)來創建套接字

其中:

family指明了協議族/域,通常AF_INET、AF_INET6、AF_LOCAL等;

type是套接口類型,主要是SOCK_STREAM、SOCK_DGRAM、SOCK_RAW;

protocol一般取為0。(默認)與特定的地址家族相關的協議,如果是 0 ,則系統就會根據地址格式和套接類別,自動選擇一個合適的協議成功時,返回一個小的非負整數值,與文件描述符類似。

創建TCP Socket:

s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

創建UDP Socket:

s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)

二、socket函數

注意:

  • TCP發送數據時,已經建立好TCP連接,所以不需要指定的地址,而UDP是面向無連接的,每次發送要指定發送給誰。
  • 服務端與客戶端不能直接發送列表,元組,字典。需要進行字符串化。

host == ip

服務端socket函數

函數 描述
s.bind(address) 將套接字綁定到地址,在AF_INET下,以tuple(host,prot)的方式傳入,如s.bind((host,port))。
s.listen(backlog) 開始監聽TCP傳入連接。backlog指定在拒絕連接之前,操作系統可以掛起的最大連接數量。該值最少為1,大部分應用程序社為5就可以了。
s.accept() 接受TCP連接並返回(conn,address),其中conn是新的套接字對象,可以用來接收和發送數據,address是連接客戶端的地址。(sock,addr = s.accept)。

客戶端socket函數

函數 描述
s.connect(address) 鏈接到address處的套接字,一般address的格式為tuple(host,port),如果鏈接出錯,則返回socket.error錯誤。
s.connect_ex(address) 功能與s.connect(address)相同,但成功返回0,失敗返回errno的值。

公共Socket函數

函數 描述
s.recv(bufsize[,flag]) 接受TCP套接字的數據,數據以字符串的形式返回,bufsize指定要接收的最大數據量,flag提供有關消息的其它消息,通常可以忽略。
s.recvfrom(bufsize[,flag]) 接受UDP套接字的數據,與recv()類似,但返回值是tuple(data,address)。其中data是包涵接受數據的字符串,address是發送數據的套接字地址。
s.send(string[,flag]) 發送TCP數據,將string中的數據發送到連接到套接字,返回值是要發送到字節數量,該數量可能小於string的字節大小。
s.sendall(string[,flag]) 完整發送TCP數據,將string中的數據發送到鏈接到套接字,但在返回之前嘗試發送所有的數據。成功返回None,失敗則拋出異常。
s.sendto(string[,flag],address) 發送UDP數據,將數據發送到套接字,address形式為tuple(hostadder,port),指定遠程地址發送,返回值是發送到字節。
s.close() 關閉套接字。
s.getpeername() 返回套接字的遠程地址,返回值通常是一個tuple(hostaddr,port)。
s.getsockname() 返回套接字自己的地址,返回值通常是一個tuple(hostaddr,port)。
s.getsockopt(level,optname[,buflen]]) 返回套接字選項的值。
s.gettimeout() 返回當前超時值,單位是秒,如果沒有設置超時值則返回None。
s.setsockopt(level, option,value) 設置給定套接字選項的值
s.settimeout(timeout) 設置套接字操作的超時時間,timeout是一個浮點數,單位是秒。值為None則表示永遠不會超時。一般超時期應在剛創建套接字時設置,因為它們可能用於連接的操作,如s.connect()。
s.setblocking(flag) 如果flag為0,則將套接字設置為非阻塞模式,否則將套接字設置為阻塞模式(默認值)。非阻塞模式下,如果調用recv()沒有發現任何數據,或send()調用無法立即發送數據,那么將引發socket.error異常。
s.makefile() 創建一個與該套接字相關的文件。
s.fileno() 返回套接字的文件描述。

三、socket編程思路

TCP服務端

1創建套接字,綁定套接字到本地IP與端口

socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.bind(("0.0.0.0",80000))

2開始監聽連接

s.listen()

3進入循環,不斷接受客戶端的連接請求

s.accept()

4然后接受傳來的數據,並發送給對方數據

s.recv()					#接收數據
s.sendall()				#發送數據

5傳輸完畢后,關閉套接字

s.close()

TCP客戶端

1創建套接字,連接遠端地址

socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(("127.0.0.1",8000))

2連接后發送數據和接受數據

s.sendall()
s.recv()

3傳輸完畢后,關閉套接字

s.close()

四、socket編程代碼

實現客戶端向服務端發送消息,代碼比較簡單,功能單一。

socket編程之服務端代碼

#socket服務端
import socket

server = socket.socket()
#綁定到0.0.0.0:8000端口上
server.bind(("0.0.0.0",8000))#0.0.0.0    同局域網下的其它機器可以通過本機ip來訪問服務器
server.listen()

#阻塞等待連接
sock,addr = server.accept()
data=""
while True:
    temp_data = sock.recv(1024)
    if temp_data:
        data += temp_data.decode("utf8")
    else:
        break

print(data)
server.close()

socket編程之客戶端代碼

#socket客戶端
import socket

client = socket.socket()
client.connect(("192.168.10.132",8000))#本機IP連接

client.send("666".encode("utf8"))
client.close()

執行效果

啟動服務端,啟動客戶端,最終效果。

服務端執行效果:

客戶端執行效果:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM