您好,登錄后才能下訂單哦!
這篇文章主要講解了“Python面向對象如何實現靜態Web服務器處理客戶端請求”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Python面向對象如何實現靜態Web服務器處理客戶端請求”吧!
把Web服務器抽象成一個類,方法初始化,在初始化中建立套接字對線。提供一個開啟Web服務器的方法,讓Web服務器處理客戶端的請求。
class HttpWebServer(object): def __init__(self): # 創建tcp服務端套接字 tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 設置端口號復用, 程序退出端口立即釋放 tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 綁定端口號 tcp_server_socket.bind(("", 9000)) # 設置監聽 tcp_server_socket.listen(128) # 保存創建成功的服務器套接字 self.tcp_server_socket = tcp_server_socket
@staticmethod def handle_client_request(new_socket): # 代碼執行到此,說明連接建立成功 recv_client_data = new_socket.recv(4096) if len(recv_client_data) == 0: print("關閉瀏覽器了") new_socket.close() return # 對二進制數據進行解碼 recv_client_content = recv_client_data.decode("utf-8") print(recv_client_content) # 根據指定字符串進行分割, 最大分割次數指定2 request_list = recv_client_content.split(" ", maxsplit=2) # 獲取請求資源路徑 request_path = request_list[1] print(request_path) # 判斷請求的是否是根目錄,如果條件成立,指定首頁數據返回 if request_path == "/": request_path = "/index.html" try: # 動態打開指定文件 with open("static" + request_path, "rb") as file: # 讀取文件數據 file_data = file.read() except Exception as e: # 請求資源不存在,返回404數據 # 響應行 response_line = "HTTP/1.1 404 Not Found\r\n" # 響應頭 response_header = "Server: PWS1.0\r\n" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body # 發送數據 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OK\r\n" # 響應頭 response_header = "Server: PWS1.0\r\n" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body # 發送數據 new_socket.send(response_data) finally: # 關閉服務與客戶端的套接字 new_socket.close()
def start(self): while True: # 等待接受客戶端的連接請求 new_socket, ip_port = self.tcp_server_socket.accept() # 當客戶端和服務器建立連接程,創建子線程 sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,)) # 設置守護主線程 sub_thread.setDaemon(True) # 啟動子線程執行對應的任務 sub_thread.start()
import socket import threading # 定義web服務器類 class HttpWebServer(object): def __init__(self): # 創建tcp服務端套接字 tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 設置端口號復用, 程序退出端口立即釋放 tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 綁定端口號 tcp_server_socket.bind(("", 9000)) # 設置監聽 tcp_server_socket.listen(128) # 保存創建成功的服務器套接字 self.tcp_server_socket = tcp_server_socket # 處理客戶端的請求 @staticmethod def handle_client_request(new_socket): # 代碼執行到此,說明連接建立成功 recv_client_data = new_socket.recv(4096) if len(recv_client_data) == 0: print("關閉瀏覽器了") new_socket.close() return # 對二進制數據進行解碼 recv_client_content = recv_client_data.decode("utf-8") print(recv_client_content) # 根據指定字符串進行分割, 最大分割次數指定2 request_list = recv_client_content.split(" ", maxsplit=2) # 獲取請求資源路徑 request_path = request_list[1] print(request_path) # 判斷請求的是否是根目錄,如果條件成立,指定首頁數據返回 if request_path == "/": request_path = "/index.html" try: # 動態打開指定文件 with open("static" + request_path, "rb") as file: # 讀取文件數據 file_data = file.read() except Exception as e: # 請求資源不存在,返回404數據 # 響應行 response_line = "HTTP/1.1 404 Not Found\r\n" # 響應頭 response_header = "Server: PWS1.0\r\n" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body # 發送數據 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OK\r\n" # 響應頭 response_header = "Server: PWS1.0\r\n" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body # 發送數據 new_socket.send(response_data) finally: # 關閉服務與客戶端的套接字 new_socket.close() # 啟動web服務器進行工作 def start(self): while True: # 等待接受客戶端的連接請求 new_socket, ip_port = self.tcp_server_socket.accept() # 當客戶端和服務器建立連接程,創建子線程 sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,)) # 設置守護主線程 sub_thread.setDaemon(True) # 啟動子線程執行對應的任務 sub_thread.start() # 程序入口函數 def main(): # 創建web服務器對象 web_server = HttpWebServer() # 啟動web服務器進行工作 web_server.start() if __name__ == '__main__': main()
感謝各位的閱讀,以上就是“Python面向對象如何實現靜態Web服務器處理客戶端請求”的內容了,經過本文的學習后,相信大家對Python面向對象如何實現靜態Web服務器處理客戶端請求這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。