• 教你如何用几行Python代码编写出一个简易Web服务器

教你如何用几行Python代码编写出一个简易Web服务器

2025-04-27 11:13:21 栏目:宝塔面板 26 阅读

python的库很丰富,只需要几行代码就能编写出一个简易 web 服务器,可以让我们快速测试python脚本。

我们这里实现的只是一个简易的 web 服务器,用在自己家软路由上还是可以的,如果你需要功能更丰富以及性能更好的web服务器,请用 apache、nginx 等专业软件。

在以前的文章中我们学习过python数据的持久化,那这里我们就提供一个web界面来进行数据的持久化和更新操作。

一、编写web服务器

使用 http.server 标准库只需要几行代码就可以启动一个web服务器了,如下代码(要用python3,python2没有http.server库):

import os
from http.server import HTTPServer, CGIHTTPRequestHandler
webdir="/var/www"
os.chdir(webdir)
HTTPServer(("192.168.56.2", 8080), CGIHTTPRequestHandler).serve_forever()

用python3执行以上代码就会启动一个监听192.168.56.2:8080地址的web服务器了,在浏览器地址栏输入 http://192.168.56.2:8080/,如果web根目录下有index.html文件就会显示此文件,如果没有就会默认显示根目录结构,如下图:

web根目录结构

二、编写展示数据脚本

cgi脚本要放在web根目录下的cgi-bin目录下,如果没有这个目录请先创建它,然后在cgi-bin目录下创建一个student.py文件,内容如下:

#!/usr/bin/env python3
import pickle
import os

student_keys = ("name", "gender", "age", "score")

if os.path.exists("student.data"):
with open("student.data", "rb") as file:
student = pickle.load(file)
student = student or {}
else:
student = {}

if not student:
student = dict.fromkeys(student_keys, "")

header = "Content-Type: text/html "
content = """





"""
print(header + content.format(**student))


name:


gender:


age:


score:




Submit


在浏览器地址栏中输入:

http://192.168.56.2:8080/cgi-bin/student.py

第一次加载时由于数据是空的,所以显示为空,如下图:

第一次加载显示数据为空

三、编写更新数据脚本

同样在cgi-bin目录下创建一个update.py文件,内容如下:

#!/usr/bin/env python3
import os
import cgi
import pickle

student_keys = ("name", "gender", "age", "score")
if os.path.exists("student.data"):
with open("student.data", "rb") as file:
student = pickle.load(file)
student = student or {}
else:
student = {}

if not student:
student = dict.fromkeys(student_keys, "")

form = cgi.FieldStorage()
for key in student_keys:
if key in form and form[key].value:
student[key] = form[key].value

with open("student.data", "wb") as file:
pickle.dump(student, file)

header = "Content-Type: text/html "
content = """


update successfully, will skip to display page: 3





"""
print(header + content)

四:验证更新功能

编写完更新脚本后,在第二步中的输入框内输入信息,如下图:

输入各项信息

然后点击提交按钮,就会跳转到更新成功页面,如下图:

更新成功页面

倒计时3秒后会跳转到展示页,这时就会有数据了,然后我们修改数据,把score 修改为100,如下图:

修改 score 为 100

点击提交按钮等再次跳转到展示页时可以看到 score 已经更新为100了。

是不是很简单,你学会了吗?


本文地址:https://www.yitenyun.com/162.html

搜索文章

Tags

数据库 API FastAPI Calcite 电商系统 MySQL 数据同步 ACK 双主架构 循环复制 Web 应用 异步数据库 序列 核心机制 生命周期 Deepseek 宝塔面板 Linux宝塔 Docker JumpServer JumpServer安装 堡垒机安装 Linux安装JumpServer esxi esxi6 root密码不对 无法登录 web无法登录 Windows Windows server net3.5 .NET 安装出错 宝塔面板打不开 宝塔面板无法访问 SSL 堡垒机 跳板机 HTTPS Windows宝塔 Mysql重置密码 无法访问宝塔面板 HTTPS加密 查看硬件 Linux查看硬件 Linux查看CPU Linux查看内存 ES 协同 修改DNS Centos7如何修改DNS scp Linux的scp怎么用 scp上传 scp下载 scp命令 防火墙 服务器 黑客 Serverless 无服务器 语言 存储 Spring SQL 动态查询 Oracle 处理机制 Linux 安全 网络架构 工具 网络配置 RocketMQ 长轮询 配置 加密 场景 MySQL 9.3 开源 PostgreSQL 存储引擎 HexHub Canal Rsync 架构 InnoDB 缓存方案 缓存架构 缓存穿透 信息化 智能运维 日志文件 MIXED 3 响应模型 线上 库存 预扣 数据库锁 监控 聚簇 非聚簇 索引 B+Tree ID 字段 数据 业务 AI 助手 单点故障 分库 分表 GreatSQL Hash 字段 优化 万能公式 云原生 DBMS 管理系统 SpringAI Redis 自定义序列化 Redis 8.0 openHalo OB 单机版 SQLite Redka ​Redis 机器学习 推荐模型 SVM Embedding PostGIS 系统 SQLark 虚拟服务器 虚拟机 内存 数据集成工具 自动重启 运维 sqlmock sftp 服务器 参数 分页查询 Netstat Linux 服务器 端口 排行榜 排序 EasyExcel MySQL8 prometheus Alert SQLite-Web 数据库管理工具 同城 双活 缓存 聚簇索引 非聚簇索引 共享锁 • 索引 • 数据库 RDB AOF 技术 Testcloud 云端自动化 查询 向量数据库 大模型 不宕机 IT 数据备份 容器化 Postgres OTel Iceberg 分布式架构 分布式锁​ 数据类型 OAuth2 Token Entity 开发 StarRocks 数据仓库 Doris SeaTunnel 分页 数据结构 连接控制 机制 AIOPS Python Web MongoDB 容器 IT运维 人工智能 推荐系统 池化技术 连接池 Caffeine CP 部署 LRU Milvus 悲观锁 乐观锁 Ftp redo log 重做日志 崖山 新版本 高可用 向量库 MVCC 事务隔离 磁盘架构 流量 MCP mini-redis INCR指令 单线程 线程 速度 服务器中毒 开放协议 Web 接口 字典 电商 QPS 高并发 微软 SQL Server AI功能 数据脱敏 加密算法 R2DBC 双引擎 RAG HelixDB 原子性 对象 Order 窗口 函数 主库 SSH 网络 频繁 Codis Crash 代码 ZODB 引擎 性能 List 类型 dbt 数据转换工具 1 PG DBA 工具链 优化器 Pottery 意向锁 记录锁 InfluxDB 模型 传统数据库 向量化 发件箱模式 事务同步 网络故障 UUIDv7 主键 仪表盘 Redisson 锁芯 LLM 线程安全 INSERT COMPACT Undo Log 连接数 订单 JOIN