欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python靜態(tài)Web服務器面向?qū)ο筇幚砜蛻舳苏埱?/h1>
 更新時間:2022年06月17日 15:51:02   作者:落雨  
這篇文章主要為大家介紹了Python面向?qū)ο髮崿F(xiàn)靜態(tài)Web服務器處理客戶端請求示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

概述

把Web服務器抽象成一個類,方法初始化,在初始化中建立套接字對線。提供一個開啟Web服務器的方法,讓Web服務器處理客戶端的請求。

實現(xiàn)步驟

1.定義web服務器類

初始化類

class HttpWebServer(object):
    def __init__(self):
        # 創(chuàng)建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))
        # 設置監(jiān)聽
        tcp_server_socket.listen(128)
        # 保存創(chuàng)建成功的服務器套接字
        self.tcp_server_socket = tcp_server_socket

處理客戶端請求

@staticmethod
    def handle_client_request(new_socket):
        # 代碼執(zhí)行到此,說明連接建立成功
        recv_client_data = new_socket.recv(4096)
        if len(recv_client_data) == 0:
            print("關閉瀏覽器了")
            new_socket.close()
            return
        # 對二進制數(shù)據(jù)進行解碼
        recv_client_content = recv_client_data.decode("utf-8")
        print(recv_client_content)
        # 根據(jù)指定字符串進行分割, 最大分割次數(shù)指定2
        request_list = recv_client_content.split(" ", maxsplit=2)
        # 獲取請求資源路徑
        request_path = request_list[1]
        print(request_path)
        # 判斷請求的是否是根目錄,如果條件成立,指定首頁數(shù)據(jù)返回
        if request_path == "/":
            request_path = "/index.html"
        try:
            # 動態(tài)打開指定文件
            with open("static" + request_path, "rb") as file:
                # 讀取文件數(shù)據(jù)
                file_data = file.read()
        except Exception as e:
            # 請求資源不存在,返回404數(shù)據(jù)
            # 響應行
            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
            # 發(fā)送數(shù)據(jù)
            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
            # 發(fā)送數(shù)據(jù)
            new_socket.send(response_data)
        finally:
            # 關閉服務與客戶端的套接字
            new_socket.close()

啟動web服務器進行工作

def start(self):
        while True:
            # 等待接受客戶端的連接請求
            new_socket, ip_port = self.tcp_server_socket.accept()
            # 當客戶端和服務器建立連接程,創(chuàng)建子線程
            sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,))
            # 設置守護主線程
            sub_thread.setDaemon(True)
            # 啟動子線程執(zhí)行對應的任務
            sub_thread.start()

代碼實現(xiàn)

import socket
import threading
# 定義web服務器類
class HttpWebServer(object):
    def __init__(self):
        # 創(chuàng)建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))
        # 設置監(jiān)聽
        tcp_server_socket.listen(128)
        # 保存創(chuàng)建成功的服務器套接字
        self.tcp_server_socket = tcp_server_socket
    # 處理客戶端的請求
    @staticmethod
    def handle_client_request(new_socket):
        # 代碼執(zhí)行到此,說明連接建立成功
        recv_client_data = new_socket.recv(4096)
        if len(recv_client_data) == 0:
            print("關閉瀏覽器了")
            new_socket.close()
            return
        # 對二進制數(shù)據(jù)進行解碼
        recv_client_content = recv_client_data.decode("utf-8")
        print(recv_client_content)
        # 根據(jù)指定字符串進行分割, 最大分割次數(shù)指定2
        request_list = recv_client_content.split(" ", maxsplit=2)
        # 獲取請求資源路徑
        request_path = request_list[1]
        print(request_path)
        # 判斷請求的是否是根目錄,如果條件成立,指定首頁數(shù)據(jù)返回
        if request_path == "/":
            request_path = "/index.html"
        try:
            # 動態(tài)打開指定文件
            with open("static" + request_path, "rb") as file:
                # 讀取文件數(shù)據(jù)
                file_data = file.read()
        except Exception as e:
            # 請求資源不存在,返回404數(shù)據(jù)
            # 響應行
            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
            # 發(fā)送數(shù)據(jù)
            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
            # 發(fā)送數(shù)據(jù)
            new_socket.send(response_data)
        finally:
            # 關閉服務與客戶端的套接字
            new_socket.close()
    # 啟動web服務器進行工作
    def start(self):
        while True:
            # 等待接受客戶端的連接請求
            new_socket, ip_port = self.tcp_server_socket.accept()
            # 當客戶端和服務器建立連接程,創(chuàng)建子線程
            sub_thread = threading.Thread(target=self.handle_client_request, args=(new_socket,))
            # 設置守護主線程
            sub_thread.setDaemon(True)
            # 啟動子線程執(zhí)行對應的任務
            sub_thread.start()
# 程序入口函數(shù)
def main():
    # 創(chuàng)建web服務器對象
    web_server = HttpWebServer()
    # 啟動web服務器進行工作
    web_server.start()
if __name__ == '__main__':
    main()

以上就是Python面向?qū)ο髮崿F(xiàn)靜態(tài)Web服務器處理客戶端請求的詳細內(nèi)容,更多關于Python面向?qū)ο箪o態(tài)Web服務器的資料請關注腳本之家其它相關文章!

相關文章

  • 用python實現(xiàn)的去除win下文本文件頭部BOM的代碼

    用python實現(xiàn)的去除win下文本文件頭部BOM的代碼

    windows環(huán)境下新建或編輯文本文件,保存時會在頭部加上BOM。使用ftp上傳到linux下,在執(zhí)行時第一行即報錯。以下方法可以去除BOM頭,有需要的朋友可以參考下
    2013-02-02
  • Python中列表復制的常用方法解析

    Python中列表復制的常用方法解析

    在Python編程中,經(jīng)常需要對列表進行復制或克隆操作,以便保護原始數(shù)據(jù)或創(chuàng)建獨立的副本,本文將詳細介紹如何在Python中進行列表克隆,以及如何選擇合適的方法來保護數(shù)據(jù),希望對大家有所幫助
    2024-02-02
  • Python實現(xiàn)網(wǎng)站表單提交和模板

    Python實現(xiàn)網(wǎng)站表單提交和模板

    今天小編就為大家分享一篇關于Python實現(xiàn)網(wǎng)站表單提交和模板,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • python入門學習關于for else的特殊特性講解

    python入門學習關于for else的特殊特性講解

    本文將介紹 Python 中的" for-else"特性,并通過簡單的示例說明如何正確使用它,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-11-11
  • Python抓取Discuz!用戶名腳本代碼

    Python抓取Discuz!用戶名腳本代碼

    這篇文章主要介紹了Python抓取Discuz!用戶名腳本代碼,有需要的朋友可以參考一下
    2013-12-12
  • Pycharm連接遠程服務器過程圖解

    Pycharm連接遠程服務器過程圖解

    這篇文章主要介紹了Pycharm連接遠程服務器過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Python?Enum枚舉類的定義及使用場景最佳實踐

    Python?Enum枚舉類的定義及使用場景最佳實踐

    枚舉(Enum)是一種有助于提高代碼可讀性和可維護性的數(shù)據(jù)類型,允許我們?yōu)橐唤M相關的常量賦予有意義的名字,在Python中,枚舉類(Enum)提供了一種簡潔而強大的方式來定義和使用枚舉
    2023-11-11
  • python微信公眾號開發(fā)簡單流程實現(xiàn)

    python微信公眾號開發(fā)簡單流程實現(xiàn)

    這篇文章主要介紹了python微信公眾號開發(fā)簡單流程實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • python里將list中元素依次向前移動一位

    python里將list中元素依次向前移動一位

    這篇文章主要介紹了python里將list中元素依次向前移動一位,以及使用racket 5.2.1實現(xiàn)此功能的代碼,希望對大家有所幫助
    2014-09-09
  • Python處理EXCEL表格導入操作分步講解

    Python處理EXCEL表格導入操作分步講解

    python操作excel主要用到xlrd和pandas兩個庫,xlrd讀取表格數(shù)據(jù),支持xlsx和xls格式的excel表格,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08

最新評論