Python面向?qū)ο笾甒eb靜態(tài)服務器
本文實例為大家分享了Python Web靜態(tài)服務器的具體代碼,供大家參考,具體內(nèi)容如下
功能:用戶訪問服務器可以返回指定頁面
步驟:
1.創(chuàng)建服務器類
2.創(chuàng)建初始化服務器配置方法
3.創(chuàng)建接收客戶端請求的方法
4.創(chuàng)建發(fā)送響應報文給客戶端方法
import socket import re import multiprocessing # Http服務器類 class HttpServer: # 初始化屬性 def __init__(self): # 創(chuàng)建套接字 self.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 設置地址重用 self.tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 綁定端口 self.tcp_server_socket.bind(("", 8080)) # 設置監(jiān)聽,最多建立128個連接 self.tcp_server_socket.listen(128) def start(self): while True: # 接收客戶端信息 client_socket, ip_port = self.tcp_server_socket.accept() print('新用戶:', ip_port, '已連接') # 創(chuàng)建新進程,給客戶端返回響應報文 t1 = multiprocessing.Process(target=self.recv_msg, args=(client_socket, ip_port)) # 啟動進程 t1.start() # 關閉客戶端套接字(多進程不共享資源,故先后需要關閉兩次套接字) client_socket.close() # 發(fā)送消息方法 @staticmethod def recv_msg(client_socket, ip_port): # 接收客戶端請求報文 client_text = client_socket.recv(1024) if not client_text: print("客戶端", ip_port, "已下線") client_socket.close() return # 請求報文解碼 client_text_str = client_text.decode() print(client_text_str) # 將請求報文切割 client_list = client_text_str.split("\r\n") # 正則匹配出請求路徑 ret = re.search(r"\s(.*)\s", client_list[0]) print(ret.group()) # 匹配不到則請求報文錯誤 if not ret: print("用戶請求報文格式錯誤!") client_socket.close() return # 得到路徑 path_info = ret.group(1) # 設置默認路徑 if path_info == '/': path_info = '/index.html' print("接收到用戶請求:", path_info) # 響應頭 response_header = "Server:Python-Web1.0\r\n" # 響應空行 response_blank = "\r\n" try: # 讀取指定路徑文件,并且返回 with open('web'+path_info, "rb") as file: # 讀取文件的二進制數(shù)據(jù) response_content = file.read() # 找不到路徑則返回404錯誤 except Exception as e: # 開始拼接響應數(shù)據(jù) response_line = "HTTP/1.1 404 Not Found\r\n" response_content = "Error !!! %s" % str(e) response_content = response_content.encode() else: # 開始拼接響應數(shù)據(jù) response_line = "HTTP/1.1 200 OK\r\n" # 拼接響應頭 response_data = (response_line + response_header + response_blank).encode() + response_content # 發(fā)送數(shù)據(jù) client_socket.send(response_data) # 關閉socket client_socket.close() if __name__ == '__main__': http1 = HttpServer() http1.start()
直接結果:可以正確的返回客戶端請求的頁面
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Python Tornado實現(xiàn)WEB服務器Socket服務器共存并實現(xiàn)交互的方法
- Python Web靜態(tài)服務器非堵塞模式實現(xiàn)方法示例
- python3實現(xiàn)微型的web服務器
- python實現(xiàn)靜態(tài)web服務器
- Tornado Web Server框架編寫簡易Python服務器
- Python Web程序部署到Ubuntu服務器上的方法
- python快速建立超簡單的web服務器的實現(xiàn)方法
- Python實現(xiàn)簡易版的Web服務器(推薦)
- python探索之BaseHTTPServer-實現(xiàn)Web服務器介紹
- Python 實現(xiàn)一個簡單的web服務器
相關文章
python-opencv-cv2.threshold()二值化函數(shù)的使用
這篇文章主要介紹了python-opencv-cv2.threshold()二值化函數(shù)的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11python?lazypredict構建大量基本模型簡化機器學習
這篇文章主要介紹了python?lazypredict構建大量基本模型簡化機器學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01Python?十大經(jīng)典排序算法實現(xiàn)詳解
排序算法是《數(shù)據(jù)結構與算法》中最基本的算法之一。排序算法可以分為內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存2022-01-01tensorflow pb to tflite 精度下降詳解
這篇文章主要介紹了tensorflow pb to tflite 精度下降詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05基于PyQt5實現(xiàn)一個串口接數(shù)據(jù)波形顯示工具
這篇文章主要為大家詳細介紹了如何利用PyQt5實現(xiàn)一個串口接數(shù)據(jù)波形顯示工具,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下2023-01-01