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 中文文档目录 官方文档 记在这里的东西我会不断的完善丰满,对于文章 ...
随机推荐
- 2019-2020-1 20199325《Linux内核原理与分析》第二周作业
冯诺依曼计算机硬件框图: 下面是一个简单的程序example.c. intadd_a_and_b(int a,int b){returna+b;}intmain(){returnadd_a_and_b ...
- java学习(第三篇)String类
一.创建一个字符串 1.String(char a[]):用一个字符数组a创建一个string类型 char a[]= {'h','e','l','l','o'}; String s=new Stri ...
- 2019-2020-1 20199329 第二周测试(环境:ubuntu64位)
2019-2020-1 20199329 第二周测试(环境:ubuntu64位) 实验一 0.每个.c一个文件,每个.h一个文件,文件名中最好有自己的学号 1.用Vi输入图中代码,并用gcc编译通过 ...
- 常用的CSS小技巧
实际开发过程中会遇到一些需要用CSS小技巧处理的布局问题,现在分享几个个人工作中遇到的小问题和解决方案. 1.inline元素间的空白间隙 这里要介绍一个神器font-size:0. 如果你写了个列表 ...
- 从实践出发:微服务布道师告诉你Spring Cloud与Boot他如何选择
背景 随着公司业务量的飞速发展,平台面临的挑战已经远远大于业务,需求量不断增加,技术人员数量增加,面临的复杂度也大大增加.在这个背景下,平台的技术架构也完成了从传统的单体应用到微服务化的演进. 系统架 ...
- Codeforce-CodeCraft-20 (Div. 2)-C. Primitive Primes(本原多项式+数学推导)
It is Professor R's last class of his teaching career. Every time Professor R taught a class, he gav ...
- TCP 可靠传输
TCP报文段首部 序号: TCP是面向字节流的.在一个TCP连接中传送的字节流中的每一个字节都按顺序编号.整个要传送的字节流的起始序号必须在连接建立时设置.首部中的序号字段值则指的是本报文段所发送的数 ...
- C - Ordering Pizza CodeForces - 867C 贪心 经典
C - Ordering Pizza CodeForces - 867C C - Ordering Pizza 这个是最难的,一个贪心,很经典,但是我不会,早训结束看了题解才知道怎么贪心的. 这个是先 ...
- 线段树 I - Transformation 加乘优先级
I - Transformation Yuanfang is puzzled with the question below: There are n integers, a 1, a 2, …, a ...
- java结合email实现自动推送
1.获取表中最后一条数据 public static String demo() throws SQLException { String sql = "select * FROM baox ...