哪里可以做公司网站网络运营策划

news/2025/10/2 14:02:50/文章来源:
哪里可以做公司网站,网络运营策划,软件属于网站开发吗,建设部网站职业资格证查询文章目录 Python静态Web服务器开发Web静态服务器初识搭建Python自带的静态Web服务器静态Web服务器返回固定页面数据静态Web服务器返回指定页面数据静态Web服务器多任务版静态Web服务器面向对象开发静态Web服务器命令行启动动态绑定端口号 Python静态Web服务器开发 Web静态服务… 文章目录 Python静态Web服务器开发Web静态服务器初识搭建Python自带的静态Web服务器静态Web服务器返回固定页面数据静态Web服务器返回指定页面数据静态Web服务器多任务版静态Web服务器面向对象开发静态Web服务器命令行启动动态绑定端口号 Python静态Web服务器开发 Web静态服务器初识 静态Web服务器是一种用于提供静态网页内容的服务器。静态网页是指在服务器上预先创建好的、不包含动态内容的网页其内容在请求之前已经确定并存储在服务器上。 与动态Web服务器相比静态Web服务器不会对请求的内容进行处理或生成。它仅仅将事先准备好的文件直接发送给客户端浏览器。这些文件可以是HTML、CSS、JavaScript、图像、视频等静态资源。 静态Web服务器的主要功能是接收HTTP请求并根据请求的URL路径返回相应的静态文件。它通常具有以下特点 提供静态文件静态Web服务器可以按照请求的URL路径查找并返回相应的静态文件。例如当用户请求/index.html时服务器会返回存储在服务器上的index.html文件。 不处理动态内容静态Web服务器不会执行服务器端的脚本或处理动态内容。它仅仅将静态文件原样发送给客户端浏览器。 高效快速由于不需要执行复杂的动态处理逻辑静态Web服务器通常能够提供较高的性能和响应速度。 缓存支持静态Web服务器通常支持缓存机制可以在客户端浏览器和服务器之间减少重复的数据传输提高加载速度和带宽利用率。 搭建Python自带的静态Web服务器 使用 python3 -m http.server 9000 命令可以启动一个简单的 HTTP 服务器并将当前目录作为静态文件服务器根目录。这样你就可以通过访问 http://localhost:9000 在本地浏览器中访问当前目录下的静态文件。python3 -m http.server 命令在 Python 3 中提供了一个简单的开发用途的 HTTP 服务器。它适用于开发和调试阶段但不适合在生产环境中使用 rootarmbian:/usr/python/static# python3 -m http.server 9000 Serving HTTP on 0.0.0.0 port 9000 (http://0.0.0.0:9000/) ...静态Web服务器返回固定页面数据 开发步骤 编写一个TCP服务端程序获取浏览器发送的HTTP请求报文数据读取固定页面数据把页面数据组装成HTTP响应报文数据发送给浏览器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/xhtmlxml,application/xml;q0.9,image/webp,image/apng,*/*;q0.8,application/signed-exchange;vb3;q0.7 Accept-Encoding: gzip, deflate Accept-Language: zh-CN,zh;q0.9,en;q0.8,en-GB;q0.7,en-US;q0.6 Cookie: psession74f200f6-b00b-4762-adea-c413ef6b9853静态Web服务器返回指定页面数据 目前的Web服务器不管用户访问什么页面返回的都是固定页面的数据 分析步骤: 获取用户请求资源的路径 # 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 根据请求资源的路径读取指定文件的数据 # 读取指定文件数据 # 使用rb的原因是浏览器也有可能请求的是图片 with open(static request_path, rb) as file:# 读取文件数据file_data file.read()组装指定文件数据的响应报文发送给浏览器 # 响应行 response_line HTTP/1.1 200 OK\r\n # 响应头 response_header Server: PWS1.0\r\nContent-Type: text/html;charsetutf-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() 判断请求的文件在服务端不存在组装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;charsetutf-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(targethandle_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(targethandle_client_request, args(client_socekt,))sub_thread.start() 静态Web服务器面向对象开发 分析步骤: 把提供服务的Web服务器抽象成一个类(HTTPWebServer)提供Web服务器的初始化方法在初始化方法里面创建Socket对象提供一个开启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(targetself.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(targetself.handle_client_request, args(client_socekt,))sub_thread.start()if __name__ __main__:# 创建服务器对象my_web_server HttpWebServer()# 启动服务器my_web_server.start() 静态Web服务器命令行启动动态绑定端口号 获取终端命令行参数动态绑定端口号的web服务器程序 获取执行python程序的终端命令行参数判断参数的类型设置端口号必须是整型给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(targetself.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()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/924974.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

做网站一定需要服务器吗网站建设首选九零后网络

文章目录 1. 依赖2. 配置文件3. 生成代码4. 详细介绍 generatorConfig.xml5. 代码详细总结 Spring MyBatis Generator 是 MyBatis 官方提供的一个强大的工具,它能够基于数据库表结构自动生成 MyBatis 持久层的代码,包括实体类、Mapper 接口和 XML 映射文…

CustomKD论文阅读 - 实践

CustomKD论文阅读 - 实践2025-10-02 13:54 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; fo…

2025 年水质测定仪厂家 TOP 企业品牌推荐排行榜,多参数,便携式,cod 快速,台式,污水,自来水,养殖,便携式总磷总氮,余氯总氯,废水水质测定仪公司推荐

当前水质监测行业正处于快速发展阶段,但同时也面临着诸多问题。一方面,市场上水质测定仪产品质量参差不齐,部分产品检测精度不足,难以满足实际监测需求,导致监测数据不准确,影响后续决策;另一方面,不同厂家的产…

AI+Decodo:构建智能电商价格监控系统的完整实战指南 - 实践

AI+Decodo:构建智能电商价格监控系统的完整实战指南 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Conso…

2025无锡考编培训品牌机构公司TOP5推荐:公考培训/事业单位考编/央企国企考编培训机构:权威师资与高效课程深度解析

在当今就业形势日趋严峻的背景下,事业单位考编培训市场呈现出蓬勃发展的态势。随着2025年招考政策预期调整,考生对培训服务的需求更加专业化、系统化。优质的考编培训机构不仅能帮助考生系统掌握考试知识点,更能提供…

RokcetMQ事务消息详解 - 实践

RokcetMQ事务消息详解 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco"…

2025冷却塔厂家权威推荐榜:高效降温与耐用品质口碑之选

2025冷却塔厂家权威推荐榜:高效降温与耐用品质口碑之选在工业生产与商业建筑领域,冷却塔作为关键的温度调控设备,其性能优劣直接影响整个系统的运行效率与能耗水平。随着2025年节能减排政策的深入推进,市场对冷却塔…

网站建设好后怎么制作网页网络广告营销推广

响应式设计,即移动端和PC端共用一个HTML模式,网站的程序和模板自动根据设备类型和屏幕大小进行自适应调整。这种方法我不喜欢,原因是不能很好保证各种客户端的效果,里面存在各种复杂的兼容性等问题。 我喜欢为不同的客户端写不同的…

使用IOT-Tree Server借助PPI协议连接西门子PLC S7-200 Smart

使用IOT-Tree Server借助PPI协议连接西门子PLC S7-200 Smartpre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Conso…

2025公考培训机构权威推荐榜:实力师资与高效备考口碑之选

2025公考培训机构权威推荐榜:实力师资与高效备考口碑之选在公务员考试竞争日趋激烈的当下,选择合适的培训机构成为考生备战过程中的关键一环。随着2025年国考临近,各大培训机构纷纷推出特色课程,如何在众多选择中找…

2025微信机器人开发指南:API接口实战

2025微信机器人开发指南:API接口实战 常见开发功能: 好友管理: 维护好友列表:包括添加、删除、修改好友信息。 分组管理:创建、编辑、删除标签,以便更好地组织好友。 消息管理: 信息发送:支持发送各种类型的消…

国家拨款农村建设查询的网站深圳市住房和建设局投诉电话

scp命令 在开发时经常会遇到两台机器之间传文件或者安装包,这就用到了scp命令 # scp [参数] 文件源 文件目标# 本地复制到远程 rootremote2:/opt/data/hadoop----->表示 用户地址:文件目录scp -r /opt/data/hadoop rootremote2:/opt/data/hadoop# 远程复…

网站长图怎么做莱芜网络推广公司哪里有

在逛INS的时候,看见国外一位叫做BastardFilms的大神制作了很多流体的效果:尤其是他制作的很多液态烟雾的流体,我特别喜欢,由于我不知道怎么下载INS的视频,所以这里只有发个截图大家看看:作者这里有说明是用…

旅游营销型网站建设电商网站分析报告

docker安装在C盘,使用一段时间后,C盘爆满。因此想把C盘中的数据迁移到其他盘,以释放C盘空间。分为以下步骤: 1、启动docker软件,打开PowerShell并切换到Docker Compose配置文件的目录。 Docker Compose配置文件的目录…

UNIX下C语言编程与实践6-Make 工具与 Makefile 编写:从基础语法到复杂计划构建实战

UNIX下C语言编程与实践6-Make 工具与 Makefile 编写:从基础语法到复杂计划构建实战pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; fo…

Mapper.xml中SQL语句的用法示例

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> …

01delphi10.3下PDFium5.8的提取文本

01delphi10.3下PDFium5.8的提取文本delphi PDFium 提取文档内容 提取文本 在窗体上放置TPdf组件Pdf1 和 TMemo组件Memo1 procedure TForm1.Button7Click(Sender: TObject); varI: Integer; begintry//读取pdf文件Pdf1.…

实用指南:Redis 哈希槽解析

实用指南:Redis 哈希槽解析pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco",…

营销型网站建设计划书网站新闻字体

在Java中&#xff0c;字符串的替换是一种常见的操作&#xff0c;特别是在处理文本和格式化输出时。Java提供了几种不同的方法来实现字符串替换&#xff0c;其中包括 replace, replaceAll 和 replaceFirst。本文将详细讨论这些方法的用法、区别以及示例。 1. replace(CharSeque…

网站引流怎么做网站注册好域名怎么办

首先检查图片路径 其次可能就是 新版本的兼容性问题 把OpenCV 4. 0.0 换成 3. 4的就好了 pip install -U opencv-python3.4.4.19 参考自https://blog.csdn.net/weixin_41279876/article/details/88682534