06 返回静态文件的映射(函数/多线程)web框架
06 返回静态文件的映射(函数/多线程)web框架
服务器server端python程序(函数版):
import socket
server = socket.socket()
server.bind(("127.0.0.1", 8888))
server.listen() def func_html(conn):
with open("index.html", "rb")as f:
conn.send(f.read()) def func_js(conn):
with open("index.js", "rb")as f:
conn.send(f.read()) def func_css(conn):
with open("index.css", "rb")as f:
conn.send(f.read()) def func_img(conn):
with open("index.png", "rb")as f:
conn.send(f.read()) def func_ico(conn):
with open("favicon.ico","rb")as f:
conn.send(f.read()) def respones_back(conn,path):
conn.send("HTTP/1.1 200 ok \r\n\r\n".encode("utf-8")) if path == "/":
func_html(conn)
elif path == "/index.js":
func_js(conn)
elif path == "/index.css":
func_css(conn)
elif path == "/index.png":
func_img(conn)
elif path == "/favicon.ico":
func_ico(conn)
conn.close() if __name__ == '__main__':
while 1:
conn, client_addr = server.accept()
http_request=conn.recv(1024).decode("utf-8")
path=http_request.split("\r\n")[0].split(" ")[1]
print("path>>>",path) respones_back(conn,path)
服务器server端python程序(函数版)
服务器server端python程序(函数映射版):
import socket
from threading import Thread,currentThread,activeCount,enumerate
server = socket.socket()
server.bind(("127.0.0.1", 8888))
server.listen()
def func_html(conn):
with open("index.html", "rb")as f:
conn.send(f.read())
def func_js(conn):
with open("index.js", "rb")as f:
conn.send(f.read())
def func_css(conn):
with open("index.css", "rb")as f:
conn.send(f.read())
def func_img(conn):
with open("index.png", "rb")as f:
conn.send(f.read())
def func_ico(conn):
with open("favicon.ico","rb")as f:
conn.send(f.read())
def respones_back(conn,path,func_mappers):
conn.send("HTTP/1.1 200 ok \r\n\r\n".encode("utf-8"))
for mapper in func_mappers:
if path == mapper[0]:
mapper[1](conn)
break
conn.close()
# if path == "/":
# func_html(conn)
# elif path == "/index.js":
# func_js(conn)
# elif path == "/index.css":
# func_css(conn)
# elif path == "/index.png":
# func_img(conn)
# elif path == "/favicon.ico":
# func_ico(conn)
# conn.close()
# 将每个请求的路径对应的执行函数进行映射,循环遍历,减少if判断
func_mappers=[("/",func_html),
("/index.js",func_js),
("/index.css",func_css),
("/index.png",func_img),
("/favicon.ico",func_ico)]
if __name__ == '__main__':
while 1:
conn, client_addr = server.accept()
http_request=conn.recv(1024).decode("utf-8")
path=http_request.split("\r\n")[0].split(" ")[1]
print("path>>>",path)
respones_back(conn,path,func_mappers)
服务器server端python程序(函数映射版)
服务器server端python程序(多线程版):
import socket
from threading import Thread,currentThread,activeCount,enumerate
server = socket.socket()
server.bind(("127.0.0.1", 8888))
server.listen()
def func_html(conn):
print("html>>>",currentThread())
with open("index.html", "rb")as f:
conn.send(f.read())
def func_js(conn):
print("js>>>", currentThread())
with open("index.js", "rb")as f:
conn.send(f.read())
def func_css(conn):
print("css>>>", currentThread())
with open("index.css", "rb")as f:
conn.send(f.read())
def func_img(conn):
print("img>>>", currentThread())
with open("index.png", "rb")as f:
conn.send(f.read())
def func_ico(conn):
print("icon>>>", currentThread())
with open("favicon.ico","rb")as f:
conn.send(f.read())
def respones_back(conn,path):
conn.send("HTTP/1.1 200 ok \r\n\r\n".encode("utf-8"))
if path == "/":
func_html(conn)
elif path == "/index.js":
func_js(conn)
elif path == "/index.css":
func_css(conn)
elif path == "/index.png":
func_img(conn)
elif path == "/favicon.ico":
func_ico(conn)
conn.close()
if __name__ == '__main__':
while 1:
conn, client_addr = server.accept()
http_request=conn.recv(1024).decode("utf-8")
path=http_request.split("\r\n")[0].split(" ")[1]
print("path>>>",path)
# respone_back(path)
#开线程进行异步处理
task=Thread(target=respones_back,args=(conn,path))
task.start()
#查看当前存活的线程和数量
# print("threads>>>",activeCount(),enumerate())
服务器server端python程序(多线程版)
服务器server端python程序(多线程映射版):
import socket
from threading import Thread,currentThread,activeCount,enumerate
server = socket.socket()
server.bind(("127.0.0.1", 8888))
server.listen()
def func_html(conn):
print("html>>>",currentThread())
with open("index.html", "rb")as f:
conn.send(f.read())
def func_js(conn):
print("js>>>", currentThread())
with open("index.js", "rb")as f:
conn.send(f.read())
def func_css(conn):
print("css>>>", currentThread())
with open("index.css", "rb")as f:
conn.send(f.read())
def func_img(conn):
print("img>>>", currentThread())
with open("index.png", "rb")as f:
conn.send(f.read())
def func_ico(conn):
print("icon>>>", currentThread())
with open("favicon.ico","rb")as f:
conn.send(f.read())
def respones_back(conn,path):
conn.send("HTTP/1.1 200 ok \r\n\r\n".encode("utf-8"))
for mapper in func_mappers:
if path == mapper[0]:
mapper[1](conn)
break
conn.close()
# if path == "/":
# func_html(conn)
# elif path == "/index.js":
# func_js(conn)
# elif path == "/index.css":
# func_css(conn)
# elif path == "/index.png":
# func_img(conn)
# elif path == "/favicon.ico":
# func_ico(conn)
# conn.close()
# 将每个请求的路径对应的执行函数进行映射,循环遍历,减少if判断
func_mappers=[("/",func_html),
("/index.js",func_js),
("/index.css",func_css),
("/index.png",func_img),
("/favicon.ico",func_ico)]
if __name__ == '__main__':
while 1:
conn, client_addr = server.accept()
http_request=conn.recv(1024).decode("utf-8")
path=http_request.split("\r\n")[0].split(" ")[1]
print("path>>>",path)
# respone_back(path)
#开线程进行异步处理
task=Thread(target=respones_back,args=(conn,path))
task.start()
#查看当前存活的线程和数量
# print("threads>>>",activeCount(),enumerate())
服务器server端python程序(多线程映射版)
index.html:

<!DOCTYPEhtml> <htmllang="en"> <head> <meta charset="UTF-8"> <link rel="stylesheet" href="index.css"> <link rel="icon" href="favicon.ico"> <title>映射版</title> </head> <body> <div id="d1"> <h1>映射版的页面:本html页面引用了外部本地css样式和js代码(本地图片)</h1> </div> <img src="index.png" alt="本地图片" title="本地图片"> </body> <scriptsrc="index.js"></script> </html>
index.html

06 返回静态文件的映射(函数/多线程)web框架的更多相关文章
- 05 返回静态文件的多线程web框架
05 返回静态文件的多线程web框架 服务器server端python程序(多线程版): import socket from threading import Thread,currentThrea ...
- 04 返回静态文件的函数web框架
04 返回静态文件的函数web框架 服务器server端python程序(函数版): import socket server = socket.socket() server.bind((" ...
- 03 返回静态文件的高级web框架
03 返回静态文件的高级web框架 服务器server端python程序(高级版): import socket server=socket.socket() server.bind(("1 ...
- flask模板应用-加载静态文件:添加Favicon,使用CSS框架,使用宏加载静态资源
加载静态文件 一个Web项目不仅需要HTML模板,还需要许多静态文件,比如CSS.JavaScript文件.图片和声音声.在flask程序中,默认需要将静态文件存储在与主脚本(包含程序实例的脚本)同级 ...
- asp.net core 系列之静态文件
这篇讲解asp.net core中的静态文件(大致翻译于官网). 静态文件,例如HTML,CSS, images和JavaScript. 要想直接被客户端访问,需要做一些配置. 一.Serve sta ...
- BCB常用文件与字符串函数
VCL库函数简介 一.BORLAND C++ BUILDER VCL的内存管理函数 1. AllocMem 在队中分配指定字节的内存块,并将分配的每一个字节初始化为 0.函数原型如下: void * ...
- Discuz!NT静态文件缓存(SQUID)
在目前最新版本的产品中,我们提供了缓存静态文件的解决方案,就是使用SQUID做静态前端,将论坛中的大部分静态文件布署或外链到一个新的HTTP链接上,其中可以外链的静态文件包括: 1.Disc ...
- Express static 托管静态文件 理解
今天偶尔看了一下服务端渲染,遇到了express.static, 在以前学习webpack配置服务端渲染时,也使用express.static 中间件,两者配置不太一样,由于当时也没有认真学,所以 一 ...
- Asp .Net core 2 学习笔记(3) —— 静态文件
这个系列的初衷是便于自己总结与回顾,把笔记本上面的东西转移到这里,态度不由得谨慎许多,下面是我参考的资源: ASP.NET Core 中文文档目录 官方文档 记在这里的东西我会不断的完善丰满,对于文章 ...
随机推荐
- union 的概念及在嵌入式编程中的应用
union 概念 union 在中文的叫法中又被称为共用体,联合或者联合体,它定义的方式与 struct 是相同的,但是意义却与 struct 完全不同,下面是 union 的定义格式: union ...
- Asp.Net Core 3.1学习-依赖注入、服务生命周期(6)
1.前言 面向对象设计(OOD)里有一个重要的思想就是依赖倒置原则(DIP),并由该原则牵引出依赖注入(DI).控制反转(IOC)及其容器等概念.在学习Core依赖注入.服务生命周期之前,下面让我们先 ...
- Element UI表格组件技巧:如何简洁实现跨页勾选、跨页统计功能
业务场景 在使用Element UI的Table组件时,常常面对这样的业务需求: 表格数据的每一项都要提供勾选框,当切换分页时,能够记忆所有页面勾选的数据,以实现批量提交不同页面勾选数据的功能.并且, ...
- 深度解析国内首个云原生数据库POLARDB的“王者荣耀”
随着移动互联网.电子商务的高速发展,被使用最多的企业级开源数据系统MySQL面临着巨大挑战--为迎接"双11"的高并发要提前做好分库分表;用户不断激增要将读写分离才能应对每天上亿次 ...
- Cisco 交换机启用netflow
Router2951#configure terminal //Creating Flow Record router2951(config)# flow record NTArecord route ...
- matlab混合编程向导(vc,vb,.net...)
一.matlab与vc混编 1.通过mcc将matlab的m文件转化为cpp,c文件或dll供vc调用: 这方面的实现推荐精华区Zosco和ljw总结的方法(x-6-1-4-3-1和2) ...
- Centos7网络配置( 网关、dns、ip地址配置)
0.前提:设置VMware的虚拟网络编辑器 子网和网关设置 虚拟网络编辑器 1.配置DNS(可忽略) $vim /etc/resolv.conf nameserver 192.168.0.1 2. ...
- C语言编程入门题目--No.12
题目:判断101-200之间有多少个素数,并输出所有素数. 1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除, 则表明此数不是素数,反之是素数. 2.程序源代码: # ...
- 数学--数论--HDU 1299 +POJ 2917 Diophantus of Alexandria (因子个数函数+公式推导)
Diophantus of Alexandria was an egypt mathematician living in Alexandria. He was one of the first ma ...
- 题目分享H 二代目
题意:有m个限制,每个限制l1,r1,l2,r2四个数,限制了一个长度为n的数第l1到r1位要与第l2到r2相同,保证r1-l1=r2-l2,求在限制下一共有多少种数 分析: 暴力的话肯定是从l1-r ...