本文執行個體形式較為詳細的講述了Python socket編程。分享給大家供大家參考。具體如下:
複製代碼 代碼如下:
sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
上面的代碼建立了一個socket對象。type參數代表通訊端類型,可為SOCK_STREAM(流通訊端)和SOCK_DGRAM(資料通訊端)。AF_INET表示建立的是ip v4的類型。
複製代碼 代碼如下:
socket(address_family,type,protocol_type):
上面三個參數的含義是:
address_family指明要建立哪一類socket。最常用的當然是ip協議,AF_INET。在unix系統中,AF_UNIX也是比較常用的,用於建立unix系統中的處理序間通訊。
type用於指定通訊類型。通常是建立連線導向的流通訊。SOCKET_DGRAM是報文通訊。如果address_family設定的是AF_INET,那麼對應的是TCP和UDP。
protocol用於指定協議類型。這個參數是可選的。在建立tcp或者是udp串連的時候他們通常都是0。如果第一個參數是AF_INET,那麼這個參數表示是ip包中的protocol欄位。
【UDP本來就不區分server和client。所有節點都是對等的】
第二步是將socket綁定到指定的地址:
複製代碼 代碼如下:
sock.bind(('localhost',7556))
第三步是使用listen方法監聽請求:【listen方法中的參數指明可接受的最大串連數】
複製代碼 代碼如下:
sock.listen(5)
第四步是不斷接收請求:收到串連請求後,這些請求需要排隊,如果隊列滿,就拒絕請求。
複製代碼 代碼如下:
connection,address = sock.accept()
accept方法返回一個含有兩個元素的 元組(connection,address)。第一個元素connection是新的socket對象,伺服器必須通過它與客戶通訊;第二個元素 address是客戶的Internet地址。
第五步是處理階段,伺服器和用戶端通過send和recv方法通訊(傳輸資料)。
如果send成功了,那麼對方的緩衝區已經有你發送的資料了。
#調用recv 時,伺服器必須指定一個整數,它對應於可通過本次方法調用來接收的最大資料量。recv方法在接收資料時會進入“blocked”狀態,最後返回一個字元 串,用它表示收到的資料。如果發送的資料量超過了recv所允許的,資料會被截短。多餘的資料將緩衝於接收端。以後調用recv時,多餘的資料會從緩衝區 刪除(以及自上次調用recv以來,客戶可能發送的其它任何資料)。
?
1 2 |
connection.settimeout(5) buf = connection.recv(1024) |
具體處理如下:
?
1 2 3 4 |
if buf == '1': connection.send('welcome to python server!') else: connection.send('please go out!') |
使用send發送資料給用戶端。用戶端使用recv來接收資料。
?
1 2 3 4 5 6 7 8 |
import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.connect(('localhost',7556)) import time time.sleep(2) sock.send('1') print sock.recv(1024) sock.close() |
這就是整個通訊過程了。
全部代碼如下:
server端:
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
#!/usr/bin/env python import socket sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM) sock.bind(('localhost',7556)) sock.listen(5) while True: connection,address = sock.accept() print "client ip is " print address try: connection.settimeout(5) buf = connection.recv(1024) if buf == '1': connection.send('welcome to python server!') else: connection.send('please go out!') except socket.timeout: print 'time out' connection.close() |
client端如下:
?
1 2 3 4 5 6 7 8 9 |
#!/usr/bin/env python import socket sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.connect(('localhost',7556)) import time time.sleep(2) sock.send('1') print sock.recv(1024) sock.close() |
記住,socket使用完畢之後要關閉。【上面的代碼,server端忘記關閉socket了】
當然,在socket串連的過程中,最好使用try except來做一下錯誤處理。
注意,accept函數和recv函數都是阻塞式的。也就是說,他們一直在等待,直到有用戶端串連過來或者是後者的有資料可以接收。
下面是一個FTP的小例子。
使用了多線程來處理每一個請求。
範例程式碼點擊此處本站下載。
如果傳輸路徑不存在則建立。
希望本文所述對大家的Python程式設計有所協助。