Python网络编程——静态Web服务器实现

简介: 可以为发出请求的浏览器提供静态文档的程序。即所访问的页面是静态的,页面中的内容不会发生变化。HTTP协议(HyperText Transfer Protocol,超文本传输协议)使用于从www服务器传输超文本到本地浏览器的传送协议。它可以使浏览器更高效,使网络传输减少。它不仅保证计算机正确快速地传输超文本,还确定传输文档中的哪一部分,以及那部分内容首先显示(如文本先于图形)等

概述

可以为发出请求的浏览器提供静态文档的程序。即所访问的页面是静态的,页面中的内容不会发生变化。HTTP协议(HyperText Transfer Protocol,超文本传输协议)使用于从www服务器传输超文本到本地浏览器的传送协议。它可以使浏览器更高效,使网络传输减少。它不仅保证计算机正确快速地传输超文本,还确定传输文档中的哪一部分,以及那部分内容首先显示(如文本先于图形)等



实现方法


方法一:使用Python自带的静态Web服务器


1.cd到网站的文件夹中

cd/www/

2.启动web服务器

python3-mhttp.server

方法二:开发自己的静态Web服务器

1.导入socket包

importsocket


2.创建tcp服务端套接字

# 创建tcp服务端套接字tcp_server_socket=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 设置端口号复用,程序退出端口号立即释放tcp_server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)


3.绑定端口号

tcp_server_socket.bind(("", 8000))


4.设置监听

tcp_server_socket.listen(128)


5.等待接受客户端的连接请求

new_socket, ip_port=tcp_server_socket.accept()


6.接收客户端的请求信息

recv_data=new_socket.recv(4096)
print(recv_data)


7.打开文件读取文件中的数据

withopen("static/index.html", "r") asfile: # 这里的file表示打开文件的对象file_data=file.read()


8.封装报文

# 响应行response_line="HTTP/1.1 200 OK\r\n"# 响应头response_header="Server: LuoYu/1.0\r\n"# 响应体response_body=file_data# 把数据封装成http 响应报文格式的数据response=response_line+response_header+"\r\n"+response_body# 把字符串编码成二进制response_data=response.encode("utf-8")


9.发送响应报文数据

new_socket.send(response_data)


10.关闭服务于客户端的套接字

new_socket.close()



代码实现

importsocket# 判断是否是主模块的代码if__name__=='__main__':
# 创建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(("", 8000))
# 设置监听tcp_server_socket.listen(128)
# 循环等待接受客户端的连接请求whileTrue:
# 等待接受客户端的连接请求new_socket, ip_port=tcp_server_socket.accept()
# 代码执行到此,说明连接建立成功# 接收客户端的请求信息recv_data=new_socket.recv(4096)
print(recv_data)
# 打开文件读取文件中的数据withopen("static/index.html", "r") asfile: # 这里的file表示打开文件的对象file_data=file.read()
# 提示: with open 关闭文件这步操作不用程序员来完成,系统帮我们来完成# 响应行response_line="HTTP/1.1 200 OK\r\n"# 响应头response_header="Server: LuoYu/1.0\r\n"# 响应体response_body=file_data# 把数据封装成http 响应报文格式的数据response=response_line+response_header+"\r\n"+response_body# 把字符串编码成二进制response_data=response.encode("utf-8")
# 发送给浏览器的响应报文数据new_socket.send(response_data)
# 关闭服务于客户端的套接字new_socket.close()


目录
相关文章
|
2月前
|
JSON 监控 API
在线网络PING接口检测服务器连通状态免费API教程
接口盒子提供免费PING检测API,可测试域名或IP的连通性与响应速度,支持指定地域节点,适用于服务器运维和网络监控。
|
2月前
|
机器学习/深度学习 存储 监控
内部文件审计:企业文件服务器审计对网络安全提升有哪些帮助?
企业文件服务器审计是保障信息安全、确保合规的关键措施。DataSecurity Plus 是由卓豪ManageEngine推出的审计工具,提供全面的文件访问监控、实时异常告警、用户行为分析及合规报告生成功能,助力企业防范数据泄露风险,满足GDPR、等保等多项合规要求,为企业的稳健发展保驾护航。
|
3月前
|
存储 运维 API
HPE OneView 10.0 - HPE 服务器、存储和网络设备集中管理软件
HPE OneView 10.0 - HPE 服务器、存储和网络设备集中管理软件
65 1
|
9天前
|
存储 弹性计算 网络协议
阿里云服务器ECS实例规格族是什么?不同规格CPU型号、处理器主频及网络性能参数均不同
阿里云ECS实例规格族是指具有不同性能特点和适用场景的实例类型集合。不同规格族如计算型c9i、通用算力型u1、经济型e等,在CPU型号、主频、网络性能、云盘IOPS等方面存在差异。即使CPU和内存配置相同,性能参数和价格也各不相同,适用于不同业务需求。
|
12天前
|
存储 监控 Linux
Dell OpenManage Enterprise 4.5 - Dell 服务器、存储和网络设备集中管理软件
Dell OpenManage Enterprise 4.5 - Dell 服务器、存储和网络设备集中管理软件
22 0
|
4月前
|
调度 Python
探索Python高级并发与网络编程技术。
可以看出,Python的高级并发和网络编程极具挑战,却也饱含乐趣。探索这些技术,你将会发现:它们好比是Python世界的海洋,有穿越风暴的波涛,也有寂静深海的奇妙。开始旅途,探索无尽可能吧!
100 15
|
4月前
|
存储 安全 Linux
Dell OpenManage Enterprise 4.4 - Dell 服务器、存储和网络设备集中管理软件
Dell OpenManage Enterprise 4.4 - Dell 服务器、存储和网络设备集中管理软件
104 4
Dell OpenManage Enterprise 4.4 - Dell 服务器、存储和网络设备集中管理软件
|
4月前
|
存储 消息中间件 弹性计算
阿里云服务器ECS计算型c7和通用算力型u1在适用场景、计算性能、网络与存储性能等方面的对比
阿里云ECS服务器u1和c7实例在适用场景、性能、处理器特性等方面存在显著差异。u1为通用算力型,性价比高,适合中小企业及对性能要求不高的场景;c7为企业级计算型,采用最新Intel处理器,性能稳定且强大,适用于高性能计算需求。u1支持多种CPU内存配比,但性能一致性可能受底层平台影响;c7固定调度模式,确保高性能与稳定性。选择时可根据预算与性能需求决定。
235 23
|
5月前
|
SQL 数据采集 人工智能
“服务器老被黑?那是你没上AI哨兵!”——聊聊基于AI的网络攻击检测那些事儿
“服务器老被黑?那是你没上AI哨兵!”——聊聊基于AI的网络攻击检测那些事儿
211 12

热门文章

最新文章

推荐镜像

更多