<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
可以為發出請求的瀏覽器提供靜態檔案的程式。
平時我們瀏覽百度新聞資料的時候,每天的新聞資料都會發生變化,那存取的這個頁面就是動態的,而我們開發的是靜態的,頁面的資料不會發生變化。
搭建Python自帶的靜態Web伺服器使用 python3 -m http.server 埠號, 效果圖如下:
-m選項說明:
-m表示執行包裡面的模組,執行這個命令的時候,需要進入你自己指定靜態檔案的目錄,然後通過瀏覽器就能存取對應的 html檔案了,這樣一個靜態的web伺服器就搭建好了。
通過瀏覽器存取搭建的靜態Web伺服器,效果圖如下:
檢視http的通訊過程,效果圖如下:
實現步驟:
import socket if __name__ == '__main__': # 建立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) while True: # 等待接受使用者端的連線請求 new_socket, ip_port = tcp_server_socket.accept() # 程式碼執行到此,說明連線建立成功 recv_client_data = new_socket.recv(4096) # 對二進位制資料進行解碼 recv_client_content = recv_client_data.decode("utf-8") print(recv_client_content) with open("static/index.html", "rb") as file: # 讀取檔案資料 file_data = file.read() # 響應行 response_line = "HTTP/1.1 200 OKrn" # 響應頭 response_header = "Server: PWS1.0rn" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) # 關閉服務與使用者端的通訊端 new_socket.close()
目前的Web伺服器,不管使用者存取什麼頁面,返回的都是固定頁面的資料,接下來需要根據使用者的請求返回指定頁面的資料
返回指定頁面資料的實現步驟:
import socket def main(): # 建立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) while True: # 等待接受使用者端的連線請求 new_socket, ip_port = tcp_server_socket.accept() # 程式碼執行到此,說明連線建立成功 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 Foundrn" # 響應頭 response_header = "Server: PWS1.0rn" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OKrn" # 響應頭 response_header = "Server: PWS1.0rn" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) finally: # 關閉服務與使用者端的通訊端 new_socket.close() if __name__ == '__main__': main()
目前的Web伺服器,不能支援多使用者同時存取,只能一個一個的處理使用者端的請求,那麼如何開發多工版的web伺服器同時處理 多個使用者端的請求?
可以使用多執行緒,比程序更加節省記憶體資源。
多工版web伺服器程式的實現步驟:
當用戶端和伺服器端建立連線成功,建立子執行緒,使用子執行緒專門處理使用者端的請求,防止主執行緒阻塞。
把建立的子執行緒設定成為守護主執行緒,防止主執行緒無法退出。
把建立的子執行緒設定成為守護主執行緒,防止主執行緒無法退出。
import socket import threading # 處理使用者端的請求 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 Foundrn" # 響應頭 response_header = "Server: PWS1.0rn" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OKrn" # 響應頭 response_header = "Server: PWS1.0rn" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) finally: # 關閉服務與使用者端的通訊端 new_socket.close() # 程式入口函數 def main(): # 建立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) while True: # 等待接受使用者端的連線請求 new_socket, ip_port = tcp_server_socket.accept() print(ip_port) # 當用戶端和伺服器建立連執行緒,建立子執行緒 sub_thread = threading.Thread(target=handle_client_request, args=(new_socket,)) # 設定守護主執行緒 sub_thread.setDaemon(True) # 啟動子執行緒執行對應的任務 sub_thread.start() if __name__ == '__main__': main()
實現步驟:
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 Foundrn" # 響應頭 response_header = "Server: PWS1.0rn" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OKrn" # 響應頭 response_header = "Server: PWS1.0rn" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").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()
實現步驟:
import socket import threading import sys # 定義web伺服器類 class HttpWebServer(object): def __init__(self, port): # 建立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(("", port)) # 設定監聽 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 Foundrn" # 響應頭 response_header = "Server: PWS1.0rn" with open("static/error.html", "rb") as file: file_data = file.read() # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").encode("utf-8") + response_body # 傳送資料 new_socket.send(response_data) else: # 響應行 response_line = "HTTP/1.1 200 OKrn" # 響應頭 response_header = "Server: PWS1.0rn" # 響應體 response_body = file_data # 拼接響應報文 response_data = (response_line + response_header + "rn").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(): print(sys.argv) # 判斷命令列引數是否等於2, if len(sys.argv) != 2: print("執行命令如下: python3 xxx.py 8000") return # 判斷字串是否都是數位組成 if not sys.argv[1].isdigit(): print("執行命令如下: python3 xxx.py 8000") return # 獲取終端命令列引數 port = int(sys.argv[1]) # 建立web伺服器物件 web_server = HttpWebServer(port) # 啟動web伺服器進行工作 web_server.start() if __name__ == '__main__': main()
到此這篇關於Python網路程式設計之HTTP協定的python應用的文章就介紹到這了,更多相關python http協定內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45