python之静态服务器程序开发

2023-11-27 21:01

本文主要是介绍python之静态服务器程序开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Python静态Web服务器开发
    • Web静态服务器初识
    • 搭建Python自带的静态Web服务器
    • 静态Web服务器返回固定页面数据
    • 静态Web服务器返回指定页面数据
    • 静态Web服务器多任务版
    • 静态Web服务器面向对象开发
    • 静态Web服务器命令行启动动态绑定端口号

Python静态Web服务器开发

Web静态服务器初识

  • 静态Web服务器是一种用于提供静态网页内容的服务器。静态网页是指在服务器上预先创建好的、不包含动态内容的网页,其内容在请求之前已经确定并存储在服务器上。

  • 与动态Web服务器相比,静态Web服务器不会对请求的内容进行处理或生成。它仅仅将事先准备好的文件直接发送给客户端浏览器。这些文件可以是HTML、CSS、JavaScript、图像、视频等静态资源。

  • 静态Web服务器的主要功能是接收HTTP请求,并根据请求的URL路径返回相应的静态文件。它通常具有以下特点:

    1. 提供静态文件:静态Web服务器可以按照请求的URL路径查找并返回相应的静态文件。例如,当用户请求/index.html时,服务器会返回存储在服务器上的index.html文件。

    2. 不处理动态内容:静态Web服务器不会执行服务器端的脚本或处理动态内容。它仅仅将静态文件原样发送给客户端浏览器。

    3. 高效快速:由于不需要执行复杂的动态处理逻辑,静态Web服务器通常能够提供较高的性能和响应速度。

    4. 缓存支持:静态Web服务器通常支持缓存机制,可以在客户端浏览器和服务器之间减少重复的数据传输,提高加载速度和带宽利用率。

搭建Python自带的静态Web服务器

  • 使用 python3 -m http.server 9000 命令可以启动一个简单的 HTTP 服务器,并将当前目录作为静态文件服务器根目录。这样,你就可以通过访问 http://localhost:9000 在本地浏览器中访问当前目录下的静态文件。
  • python3 -m http.server 命令在 Python 3 中提供了一个简单的开发用途的 HTTP 服务器。它适用于开发和调试阶段,但不适合在生产环境中使用
root@armbian:/usr/python/static# python3 -m http.server 9000
Serving HTTP on 0.0.0.0 port 9000 (http://0.0.0.0:9000/) ...

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

静态Web服务器返回固定页面数据

  • 开发步骤:
    1. 编写一个TCP服务端程序
    2. 获取浏览器发送的HTTP请求报文数据
    3. 读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器
    4. HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字。
      在这里插入图片描述
  • TCP服务端程序代码
import socketif __name__ == '__main__':# 1.编写一个TCP服务端程序# 创建socekttcp_server_socekt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口复用 tcp_server_socekt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定地址tcp_server_socekt.bind(("", 8080))# 设置监听tcp_server_socekt.listen(128)while True:# 2.获取浏览器发送的HTTP请求报文数据# 建立链接client_socekt, client_addr = tcp_server_socekt.accept()# 获取浏览器的请求信息client_request_data = client_socekt.recv(1024).decode()print(client_request_data)# 3.读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器with open("./static/index.html", "rb") as f:file_data = f.read()# 应答行response_line = "HTTP/1.1 200 OK\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = file_data# 应答数据response_data = (response_line + response_header + "\r\n").encode() + response_bodyclient_socekt.send(response_data)# 4.HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字client_socekt.close()

在这里插入图片描述

  • 服务器终端输出的内容
    GET / HTTP/1.1
    Host: 192.168.1.30:8080
    Connection: keep-alive
    Upgrade-Insecure-Requests: 1
    User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 Edg/119.0.0.0
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7
    Accept-Encoding: gzip, deflate
    Accept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6
    Cookie: psession=74f200f6-b00b-4762-adea-c413ef6b9853
    

静态Web服务器返回指定页面数据

  • 目前的Web服务器,不管用户访问什么页面,返回的都是固定页面的数据
    在这里插入图片描述
  • 分析步骤:
    1. 获取用户请求资源的路径
    # GET /index2.html HTTP/1.1xxxxxxxclient_request_conent = client_request_data.decode(“utf-8”)
    # 使用空格分割用户请求的数据
    request_list = client_request_conent.split(” ”) 
    # 获取用户请求的资源路径
    request_path = request_list[1] 
    print(request_path)
    if request_path == "/":# 如果用户没有指定资源路径那么默认访问的数据是首页的数据request_path = "/index.html"
    1. 根据请求资源的路径,读取指定文件的数据
    # 读取指定文件数据
    # 使用rb的原因是浏览器也有可能请求的是图片
    with open("static" + request_path, "rb") as file:# 读取文件数据file_data = file.read()
    
    1. 组装指定文件数据的响应报文,发送给浏览器
    # 响应行
    response_line = "HTTP/1.1 200 OK\r\n"
    # 响应头
    response_header = "Server: PWS1.0\r\nContent-Type: text/html;charset=utf-8\r\n"
    # 响应体
    response_body = file_data
    # 拼接响应报文数据
    response_data = (response_line + response_header + "\r\n").encode("utf-8") + response_body
    # 发送响应报文数据
    conn_socket.send(response_data)
    conn_socket.close()
    1. 判断请求的文件在服务端不存在,组装404状态的响应报文,发送给浏览器
try:# 打开指定文件,代码省略...except Exception as e:response_line = “HTTP/1.1 404 Not Found\r\n”  response_header = “Server: PWS1.0\r\nContent-Type: text/html;charset=utf-8\r\n”response_body =<h1>非常抱歉,您当前访问的网页已经不存在了</h1>.encode(“utf-8)response_data = (response_line + response_header + “\r\n”).encode(“utf-8) + response_body# 发送404响应报文数据conn_socket.send(response_data)else:    # 发送指定页面的响应报文数据,代码省略...finally:conn_socket.close()
  • 完整的内容
import socket# 1 获取用户请求资源的路径
# 2 根据请求资源的路径,读取指定文件的数据
# 3 组装指定文件数据的响应报文,发送给浏览器
# 4 判断请求的文件在服务端不存在,组装404状态的响应报文,发送给浏览器if __name__ == '__main__':# 1.编写一个TCP服务端程序# 创建socekttcp_server_socekt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口复用 tcp_server_socekt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定地址tcp_server_socekt.bind(("", 8080))# 设置监听tcp_server_socekt.listen(128)while True:# 2.获取浏览器发送的HTTP请求报文数据# 建立链接client_socekt, client_addr = tcp_server_socekt.accept()# 获取浏览器的请求信息client_request_data = client_socekt.recv(1024).decode()if len(client_request_data) <= 1:print("客户端已经关闭")print(client_request_data)else:# 获取用户请求资源的路径requst_data = client_request_data.split(" ")print(requst_data)# 求资源的路径request_path = requst_data[1]if request_path == "/":request_path = "/index.html"# 3.读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器# 根据请求资源的路径,读取指定文件的数据try:with open("./static" + request_path, "rb") as f:file_data = f.read()except Exception as e:# 返回404错误数据# 应答行response_line = "HTTP/1.1 404 Not Found\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = "404 Not Found sorry"# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n" + response_body).encode()client_socekt.send(response_data)else:# 应答行response_line = "HTTP/1.1 200 OK\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = file_data# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n").encode() + response_bodyclient_socekt.send(response_data)finally:# 4.HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字client_socekt.close()

静态Web服务器多任务版

  • 开发多任务版的Web服务器同时处理多个客户端的请求,可以使用多线程,比进程更加节省内存资源。
  • 当客户端和服务端建立连接成功,创建子线程,使用子线程专门处理客户端的请求,防止主线程阻塞
     while True:conn_socket, ip_port = tcp_server_socket.accept()# 开辟子线程并执行对应的任务sub_thread = threading.Thread(target=handle_client_request, args=(conn_socket,))
    
  • 完整的代码
    import socket
    import threading# 获取用户请求资源的路径
    # 根据请求资源的路径,读取指定文件的数据
    # 组装指定文件数据的响应报文,发送给浏览器
    # 判断请求的文件在服务端不存在,组装404状态的响应报文,发送给浏览器def handle_client_request(client_socekt):# 获取浏览器的请求信息client_request_data = client_socekt.recv(1024).decode()print(client_request_data)# 获取用户请求资源的路径requst_data = client_request_data.split(" ")print(requst_data)# 判断客户端是否关闭if len(requst_data) == 1:client_socekt.close()return# 求资源的路径request_path = requst_data[1]if request_path == "/":request_path = "/index.html"# 3.读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器# 根据请求资源的路径,读取指定文件的数据try:with open("./static" + request_path, "rb") as f:file_data = f.read()except Exception as e:# 返回404错误数据# 应答行response_line = "HTTP/1.1 404 Not Found\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = "404 Not Found sorry"# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n" + response_body).encode()client_socekt.send(response_data)else:# 应答行response_line = "HTTP/1.1 200 OK\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = file_data# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n").encode() + response_bodyclient_socekt.send(response_data)finally:# 4.HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字client_socekt.close()if __name__ == '__main__':# 1.编写一个TCP服务端程序# 创建socekttcp_server_socekt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口复用 tcp_server_socekt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定地址tcp_server_socekt.bind(("", 8080))# 设置监听tcp_server_socekt.listen(128)while True:# 2.获取浏览器发送的HTTP请求报文数据# 建立链接client_socekt, client_addr = tcp_server_socekt.accept()# 创建子线程sub_thread = threading.Thread(target=handle_client_request, args=(client_socekt,))sub_thread.start()

静态Web服务器面向对象开发

  • 分析步骤:
    1. 把提供服务的Web服务器抽象成一个类(HTTPWebServer)
    2. 提供Web服务器的初始化方法,在初始化方法里面创建Socket对象
    3. 提供一个开启Web服务器的方法,让Web服务器处理客户端请求操作
class HttpWebServer(object):def __init__(self):# 初始化服务端套接字,设置监听,代码省略...# 启动服务器def start(self):while True:conn_socket, ip_port = self.tcp_server_socket.accept()# 连接建立成功,开辟子线程处理客户端的请求sub_thread = threading.Thread(target=self.handle_client_request, args=(conn_socket,))sub_thread.start()@staticmethoddef handle_client_request(conn_socket):# 根据用户请求,响应对应资源数据,代码省略...
import socket
import threading# 获取用户请求资源的路径
# 根据请求资源的路径,读取指定文件的数据
# 组装指定文件数据的响应报文,发送给浏览器
# 判断请求的文件在服务端不存在,组装404状态的响应报文,发送给浏览器
class HttpWebServer:def __init__(self):# 1.编写一个TCP服务端程序# 创建socektself.tcp_server_socekt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口复用 self.tcp_server_socekt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定地址self.tcp_server_socekt.bind(("", 8080))# 设置监听self.tcp_server_socekt.listen(128)def handle_client_request(self, client_socekt):# 获取浏览器的请求信息client_request_data = client_socekt.recv(1024).decode()print(client_request_data)# 获取用户请求资源的路径requst_data = client_request_data.split(" ")print(requst_data)# 判断客户端是否关闭if len(requst_data) == 1:client_socekt.close()return# 求资源的路径request_path = requst_data[1]if request_path == "/":request_path = "/index.html"# 3.读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器# 根据请求资源的路径,读取指定文件的数据try:with open("./static" + request_path, "rb") as f:file_data = f.read()except Exception as e:# 返回404错误数据# 应答行response_line = "HTTP/1.1 404 Not Found\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = "404 Not Found sorry"# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n" + response_body).encode()client_socekt.send(response_data)else:# 应答行response_line = "HTTP/1.1 200 OK\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = file_data# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n").encode() + response_bodyclient_socekt.send(response_data)finally:# 4.HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字client_socekt.close()def start(self):while True:# 2.获取浏览器发送的HTTP请求报文数据# 建立链接client_socekt, client_addr = self.tcp_server_socekt.accept()# 创建子线程sub_thread = threading.Thread(target=self.handle_client_request, args=(client_socekt,))sub_thread.start()if __name__ == '__main__':# 创建服务器对象my_web_server = HttpWebServer()# 启动服务器my_web_server.start()

静态Web服务器命令行启动动态绑定端口号

  • 获取终端命令行参数动态绑定端口号的web服务器程序

    1. 获取执行python程序的终端命令行参数
    2. 判断参数的类型,设置端口号必须是整型
    3. 给Web服务器类的初始化方法添加一个端口号参数,用于绑定端口号
  • 完整代码演示:

import socket
import threading
import sys# 获取用户请求资源的路径
# 根据请求资源的路径,读取指定文件的数据
# 组装指定文件数据的响应报文,发送给浏览器
# 判断请求的文件在服务端不存在,组装404状态的响应报文,发送给浏览器
class HttpWebServer:def __init__(self, port):# 1.编写一个TCP服务端程序# 创建socektself.tcp_server_socekt = socket.socket(socket.AF_INET, socket.SOCK_STREAM)# 设置端口复用 self.tcp_server_socekt.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)# 绑定地址self.tcp_server_socekt.bind(("", port))# 设置监听self.tcp_server_socekt.listen(128)def handle_client_request(self, client_socekt):# 获取浏览器的请求信息client_request_data = client_socekt.recv(1024).decode()print(client_request_data)# 获取用户请求资源的路径requst_data = client_request_data.split(" ")print(requst_data)# 判断客户端是否关闭if len(requst_data) == 1:client_socekt.close()return# 求资源的路径request_path = requst_data[1]if request_path == "/":request_path = "/index.html"# 3.读取固定页面数据,把页面数据组装成HTTP响应报文数据发送给浏览器# 根据请求资源的路径,读取指定文件的数据try:with open("./static" + request_path, "rb") as f:file_data = f.read()except Exception as e:# 返回404错误数据# 应答行response_line = "HTTP/1.1 404 Not Found\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = "404 Not Found sorry"# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n" + response_body).encode()client_socekt.send(response_data)else:# 应答行response_line = "HTTP/1.1 200 OK\r\n"# 应答头response_header = "Server:pwb\r\n"# 应答体response_body = file_data# 应答数据# 组装指定文件数据的响应报文,发送给浏览器response_data = (response_line + response_header + "\r\n").encode() + response_bodyclient_socekt.send(response_data)finally:# 4.HTTP响应报文数据发送完成以后,关闭服务于客户端的套接字client_socekt.close()def start(self):while True:# 2.获取浏览器发送的HTTP请求报文数据# 建立链接client_socekt, client_addr = self.tcp_server_socekt.accept()# 创建子线程sub_thread = threading.Thread(target=self.handle_client_request, args=(client_socekt,))sub_thread.start()def main():# 获取执行python程序的终端命令行参数print(sys.argv)# 检查 sys.argv 列表的长度是否为 2。如果长度不等于 2,说明传递给脚本的参数数量不正确if len(sys.argv) != 2:print("格式错误 python3 xxx.py 9090")return# 判断参数的类型,设置端口号必须是整型if not sys.argv[1].isdigit():print("格式错误 python3 xxx.py 9090")returnport = int(sys.argv[1])# 创建服务器对象# 给Web服务器类的初始化方法添加一个端口号参数,用于绑定端口号my_web_server = HttpWebServer(port)# 启动服务器my_web_server.start()if __name__ == '__main__':main()

这篇关于python之静态服务器程序开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428472

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta