python靜態(tài)web服務(wù)器實現(xiàn)方法及代碼詳解
1、編寫TCP服務(wù)器程序。
2、獲取瀏覽器發(fā)送的http請求消息數(shù)據(jù)。
3、讀取固定的頁面數(shù)據(jù),將頁面數(shù)據(jù)組裝成HTTP響應(yīng)消息數(shù)據(jù)并發(fā)送給瀏覽器。
4、HTTP響應(yīng)報文數(shù)據(jù)發(fā)送完成后,關(guān)閉服務(wù)于客戶端的套接字。
實例
# 時間: 2021/10/21 20:38 import socket if __name__ == '__main__': # 創(chuàng)建tcp服務(wù)端套接字 tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 設(shè)置端口號復(fù)用, 程序退出端口立即釋放 tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True) # 綁定端口號 tcp_server_socket.bind(("", 8080)) # 設(shè)置監(jiān)聽 tcp_server_socket.listen(128) while True: # 等待接受客戶端的連接請求 new_socket, ip_port = tcp_server_socket.accept() # 代碼執(zhí)行到此,說明連接建立成功 recv_client_data = new_socket.recv(4096) # 對二進制數(shù)據(jù)進行解碼 recv_client_content = recv_client_data.decode) print(recv_client_content) # 響應(yīng)行 response_line = "HTTP/1.1 200 OK\r\n" # 響應(yīng)頭 response_header = "Server: py1.0\r\n" # 響應(yīng)體 response_body = "Hello,guys!" # 拼接響應(yīng)報文 response_data = (response_line + response_header + "\r\n"+ response_body).encode() # 發(fā)送數(shù)據(jù) new_socket.send(response_data) # 關(guān)閉服務(wù)與客戶端的套接字 new_socket.close()
實例擴展:
import socket import re import time def service_client(new_socket): """為這個客戶端服務(wù)""" # 1.接收瀏覽器發(fā)送過來的請求,即http請求 # GET / HTTP/1.1 # -------- request = new_socket.recv(1024).decode('utf-8') # 判斷客戶端意外斷開鏈接返回空字符串 if not request: # 關(guān)閉套接字并退出 new_socket.close() print("==="*30) return # 分隔套接字 request_lines = request.splitlines() print() print(">"*20) print(request_lines) file_name = "" ret = re.match(r"[^/]+(/[^ ]*)", request_lines[0]) if ret: file_name = ret.group(1) if file_name == "/": file_name = "/index.html" # 2.返回http格式數(shù)據(jù) 給瀏覽器 try: f = open("./html" + file_name, "rb") except: response = "HTTP/1.1 404 NOT FOUND\r\n" response += "Content-Type:text/html;charset=utf-8\r\n" response += "\r\n" response += "<h1>404 not found <br> 沒有發(fā)現(xiàn)所請求資源</h1>" response += str(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time()))) new_socket.send(response.encode('utf-8')) else: html_content = f.read() f.close() # 2.1準(zhǔn)備發(fā)送給瀏覽器的數(shù)據(jù)---header response = "HTTP/1.1 200 OK\r\n" response += "\r\n" # 2.2準(zhǔn)備發(fā)送給瀏覽器的數(shù)據(jù) ---body # 將response header發(fā)送給瀏覽器 new_socket.send(response.encode("utf-8")) # 將response body發(fā)送給瀏覽器 new_socket.send(html_content) # 關(guān)閉套接字 new_socket.close() def main(): """用來完成整體的控制""" # 1.創(chuàng)建套接字 tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 端口復(fù)用 tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 2.綁定 tcp_server_socket.bind(("", 7890)) # 3.變?yōu)樘捉幼? tcp_server_socket.listen(128) while True: # 4.等待客戶端的鏈接 new_socket, client_addr = tcp_server_socket.accept() print(client_addr) # 5.為這個客戶端服務(wù) service_client(new_socket) # 關(guān)閉監(jiān)聽套接字 tcp_server_socket.close() if __name__ == '__main__': main()
到此這篇關(guān)于python靜態(tài)web服務(wù)器實現(xiàn)方法及代碼詳解的文章就介紹到這了,更多相關(guān)python靜態(tài)web服務(wù)器如何實現(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于PyQt5實現(xiàn)狀態(tài)欄(statusBar)顯示和隱藏功能
這篇文章主要為大家詳細介紹了如何利用PyQt5實現(xiàn)狀態(tài)欄顯示和隱藏功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-08-08Pytest+Request+Allure+Jenkins實現(xiàn)接口自動化
這篇文章介紹了Pytest+Request+Allure+Jenkins實現(xiàn)接口自動化的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06Python pypinyin注音庫輕松絲滑實現(xiàn)漢字轉(zhuǎn)換成拼音
pypinyin 庫,能像功夫熊貓那樣,輕松、快捷地幫你把漢字轉(zhuǎn)換成拼音,有了 pypinyin,不僅可以節(jié)省寶貴的時間,還可以更準(zhǔn)確地展示中文字符的讀音,使文化交流更為順暢,本文帶大家一起探索 pypinyin 庫的魅力2024-01-01淺談django url請求與數(shù)據(jù)庫連接池的共享問題
今天小編就為大家分享一篇淺談django url請求與數(shù)據(jù)庫連接池的共享問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08