Python下的socket編程,Pythonsocket編程
首先需要說明的一點是:這裡並不會記錄很深奧的socket編程,只是會分析一個最簡單的socket編程聊天室下的幾種特殊異常情況的處理,代碼如下:
服務端:
1 import socket 2 3 HOST = "" 4 PORT = 8870 5 sk = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 6 sk.bind((HOST, PORT)) 7 sk.listen(5) 8 while True: 9 print("伺服器啟動")10 conn, addr = sk.accept()11 print(addr)12 while True:13 try:14 server_recv_data = conn.recv(1024) #若用戶端輸入exit退出,則此處並沒有阻塞,只是收到的資訊為空白15 #若用戶端輸入空,即直接按下斷行符號鍵,那麼此處將會被阻塞16 if len(server_recv_data) == 0:17 print("收到為空白")18 break19 except ConnectionResetError as err:20 print(err)21 break22 print(str(server_recv_data, encoding="utf-8"))23 server_resp_data = input(">>>")24 conn.sendall(bytes(server_resp_data, encoding="utf-8"))25 conn.close()26 sk.close()
用戶端:
1 import socket 2 3 HOST = "127.0.0.1" 4 PORT = 8870 5 sk = socket.socket() 6 sk.connect((HOST, PORT)) 7 print("用戶端啟動...") 8 9 while True:10 inp = input(">>>")11 if inp == "exit"or not inp: #此處需要說明的是,當直接在用戶端按下斷行符號enter鍵的時候,inp為空白12 break13 sk.sendall(bytes(inp, encoding="utf-8"))14 server_response = sk.recv(1024)15 print(str(server_response, encoding="utf-8"))16 sk.close()注意:
1.當用戶端強行關閉的時候(比如在pycharm中按下調試視窗左端的stop按鈕時),用戶端當然會報錯,但是在Linux系統上,服務端不會報錯,只是認為接收到的資訊為空白,即此處的server_recv_data為空白,所以在此服務端做了一個判斷退出內層迴圈,以便可以串連其他的用戶端發送來的串連請求;
2.當用戶端輸入exit表示要退出當前聊天的時候,此處用戶端if判斷break退出,關鍵是此時的服務端得到的結果是,server_recv_data為空白,與上面情況一樣;
3.唯一可以讓服務端的server——recv_data = conn.recv(1024)發生阻塞的是:用戶端直接按下斷行符號,此時一個尷尬的情況是服務端仍然等待用戶端發送資訊(認為沒有資訊到來),用戶端無法再發送資訊,因為剛才已經按斷行符號了,雖然可以再輸入資訊,但是無法發送了(即使再按斷行符號也沒用),所以為瞭解決這個問題,我們預設認為當用戶端做出這個動作的時候表示要退出,此時inp為空白,所以在用戶端做出了if not inp:的判斷,退出聊天,服務端收到為空白,break之後繼續等待其他串連