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()
執行效果
啟動服務端,啟動客戶端,最終效果。
服務端執行效果:
客戶端執行效果: