Python面向?qū)ο笾甒eb靜態(tài)服務(wù)器
本文實例為大家分享了Python Web靜態(tài)服務(wù)器的具體代碼,供大家參考,具體內(nèi)容如下
功能:用戶訪問服務(wù)器可以返回指定頁面
步驟:
1.創(chuàng)建服務(wù)器類
2.創(chuàng)建初始化服務(wù)器配置方法
3.創(chuàng)建接收客戶端請求的方法
4.創(chuàng)建發(fā)送響應(yīng)報文給客戶端方法
import socket
import re
import multiprocessing
# Http服務(wù)器類
class HttpServer:
# 初始化屬性
def __init__(self):
# 創(chuàng)建套接字
self.tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 設(shè)置地址重用
self.tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# 綁定端口
self.tcp_server_socket.bind(("", 8080))
# 設(shè)置監(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)建新進(jìn)程,給客戶端返回響應(yīng)報文
t1 = multiprocessing.Process(target=self.recv_msg, args=(client_socket, ip_port))
# 啟動進(jìn)程
t1.start()
# 關(guān)閉客戶端套接字(多進(jìn)程不共享資源,故先后需要關(guān)閉兩次套接字)
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)
# 設(shè)置默認(rèn)路徑
if path_info == '/':
path_info = '/index.html'
print("接收到用戶請求:", path_info)
# 響應(yīng)頭
response_header = "Server:Python-Web1.0\r\n"
# 響應(yīng)空行
response_blank = "\r\n"
try:
# 讀取指定路徑文件,并且返回
with open('web'+path_info, "rb") as file:
# 讀取文件的二進(jìn)制數(shù)據(jù)
response_content = file.read()
# 找不到路徑則返回404錯誤
except Exception as e:
# 開始拼接響應(yīng)數(shù)據(jù)
response_line = "HTTP/1.1 404 Not Found\r\n"
response_content = "Error !!! %s" % str(e)
response_content = response_content.encode()
else:
# 開始拼接響應(yīng)數(shù)據(jù)
response_line = "HTTP/1.1 200 OK\r\n"
# 拼接響應(yīng)頭
response_data = (response_line + response_header + response_blank).encode() + response_content
# 發(fā)送數(shù)據(jù)
client_socket.send(response_data)
# 關(guān)閉socket
client_socket.close()
if __name__ == '__main__':
http1 = HttpServer()
http1.start()
直接結(jié)果:可以正確的返回客戶端請求的頁面


以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python Tornado實現(xiàn)WEB服務(wù)器Socket服務(wù)器共存并實現(xiàn)交互的方法
- Python Web靜態(tài)服務(wù)器非堵塞模式實現(xiàn)方法示例
- python3實現(xiàn)微型的web服務(wù)器
- python實現(xiàn)靜態(tài)web服務(wù)器
- Tornado Web Server框架編寫簡易Python服務(wù)器
- Python Web程序部署到Ubuntu服務(wù)器上的方法
- python快速建立超簡單的web服務(wù)器的實現(xiàn)方法
- Python實現(xiàn)簡易版的Web服務(wù)器(推薦)
- python探索之BaseHTTPServer-實現(xiàn)Web服務(wù)器介紹
- Python 實現(xiàn)一個簡單的web服務(wù)器
相關(guān)文章
python-opencv-cv2.threshold()二值化函數(shù)的使用
這篇文章主要介紹了python-opencv-cv2.threshold()二值化函數(shù)的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11
python?lazypredict構(gòu)建大量基本模型簡化機器學(xué)習(xí)
這篇文章主要介紹了python?lazypredict構(gòu)建大量基本模型簡化機器學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01
Python?十大經(jīng)典排序算法實現(xiàn)詳解
排序算法是《數(shù)據(jù)結(jié)構(gòu)與算法》中最基本的算法之一。排序算法可以分為內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存2022-01-01
tensorflow pb to tflite 精度下降詳解
這篇文章主要介紹了tensorflow pb to tflite 精度下降詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
基于PyQt5實現(xiàn)一個串口接數(shù)據(jù)波形顯示工具
這篇文章主要為大家詳細(xì)介紹了如何利用PyQt5實現(xiàn)一個串口接數(shù)據(jù)波形顯示工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-01-01

