Python学习---基于HTTP的服务端基础框架搭建案例

整体功能:

1 创建框架构建相关的文件夹

2 创建app,模块文件
3 在 app模块文件中创建application函数(用于处理请求)
4 将request_handler()中的处理逻辑交由app模块的application函数完成

5 app模块的 application函数返回响应报文

6 在application 文件夹中创建一个utils 模块
7 utils 模块中创建 create_http_response() 函数,专门用来拼接响应报文
8 修改 app模块的application的返回响应协议的部分

逻辑关系:

文件架构:

main.py

python 复制代码
# TCP服务端
import socket
from application import app


class WebServer(object):
    def __init__(self):
        # 1,导入模块
        # 2·创建套接字
        tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        # 3·设置地址重用
        tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
        # 4、绑定端口
        address = ("", 10000)
        tcp_server_socket.bind(address)
        # 5﹑设置监听·让套接字由主动变为被动接收
        tcp_server_socket.listen(128)
        self.tcp_server_socket = tcp_server_socket

    def start(self):
        """
        启动Web服务器
        """
        # 6﹑接受客户端连接 定义函数request------handler()
        while True:
            new_client_socket, ip_port = self.tcp_server_socket.accept()
            print(f"新的连接请求:{ip_port}")
            # 调用函数处理请求
            self.request_handler(new_client_socket, ip_port)

    def request_handler(self, new_client_socket, ip_port):
        """
        接收数据并响应
        :return:
        """
        # 7.接收客户端浏览器发送的请求协议
        request_data = new_client_socket.recv(1024)
        # 8﹑判断协议是否为空
        if not request_data:
            print(f"{str(ip_port)}客户端已经下线!!!")
            new_client_socket.close()
            return
        # 使用application文件夹下的app模块处理
        response_data = app.application("static", request_data, ip_port)
        new_client_socket.send(response_data)
        new_client_socket.close()
        return


def main():
    # 创建对象
    ws = WebServer()
    ws.start()


if __name__ == '__main__':
    main()

app.py

python 复制代码
"""
解析客户端浏览器发送的消息,并将响应信息发回
"""
from application import utils

def parse_request(request_data, ip_port):
    """
    解析请求报文,返回客户端请求的资源路径
    :param request_data: 接受到的客户端请求信息
    :param ip_port: 客户端IP地址
    :return: 客户端请求的资源路径
    """
    # 根据客户端请求的资源返回对应资源
    # 1 解码得到请求字符串
    request_text = request_data.decode()
    loc = request_text.find("\r\n")
    # 2 得到请求行
    request_line = request_text[:loc]
    # 3按空格拆分得到对应信息
    request_line_list = request_line.split(" ")
    file_path = request_line_list[1]
    print(f"{str(ip_port)}正在请求{file_path}资源,服务器已成功响应!")
    # 设置默认首页
    if file_path == "/":
        file_path = "/index.html"
    return file_path


def application(current_dir, request_data, ip_port):
    """
    解析客户端的请求信息,找到目标资源路径并返回资源
    :param current_dir:服务器资源根目录
    :param request_data: 客户端请求资源信息
    :param ip_port: 客户端IP地址
    :return: 客户端请求的内容
    """
    file_path = parse_request(request_data, ip_port)
    resource_path = current_dir + file_path

    # 9.4响应主体
    # response_body = "<html><h>HelloWorld!<h/><html/>"
    # 通过读取文件内容返回客户端
    try:
        with open(resource_path, "rb") as file:
            response_body = file.read()
        response_data=utils.create_http_response("200 OK", response_body)
    except Exception as e:
        # 重新修改响应行404
        response_body = f"Error! {str(e)}".encode()
        response_data = utils.create_http_response("404 Not Found", response_body)
    # 10、发送响应报文

    return response_data

utils.py

python 复制代码
def create_http_response(status, response_body):
    # 9﹑拼接响应的报文
    # 9.1响应行
    response_line = f"HTTP/1.1 {status}\r\n"
    # 9.2响应头
    response_header = "Server:Python20ws/21.1\r\n"
    # 9.3响应空行
    response_blank = "\r\n"
    response_data = (response_line + response_header + response_blank).encode() + response_body
    return response_data
相关推荐
学编程的闹钟17 分钟前
107【php手册】
学习
冷雨夜中漫步8 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴8 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再8 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
绵绵细雨中的乡音8 小时前
深入理解 ET 与 LT 模式及其在 Reactor 模型中的应用
服务器·网络·php
盐焗西兰花9 小时前
鸿蒙学习实战之路-Reader Kit修改翻页方式字体大小及行间距最佳实践
学习·华为·harmonyos
暖馒9 小时前
Modbus应用层协议的深度剖析
网络·网络协议·c#·wpf·智能硬件
QiZhang | UESTC9 小时前
学习日记day76
学习
久邦科技9 小时前
20个免费电子书下载网站,实现电子书自由(2025持续更新)
学习
喵手10 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控