简单的web框架(python)

1、web框架介绍

Web框架(Web framework)是一种开发框架,用来支持动态网站、网络应用和网络服务的开发。这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方法。web框架已经实现了很多功能,开发人员使用框架提供的方法并且完成自己的业务逻辑,就能快速开发web应用了。浏览器和服务器的是基于HTTP协议进行通信的。也可以说web框架就是在以上十几行代码基础张扩展出来的,有很多简单方便使用的方法,大大提高了开发的效率。

 

2、实现简单的web框架

基于socket写一个web应用

第一版本   

  通过HTTP协议传送过来的信息返回页面

import socketserver = socket.socket()
server.bind(('127.0.0.1',8000))
server.listen(5)while True:conn,addr = server.accept()while True:data = conn.recv(1024)'''***data***b'GET /index/ HTTP/1.1\r\nHost: 127.0.0.1:8000\r\nConnection: keep-alive\r\nUpgrade-Insecure-Requests: 1\r\nUser-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36\r\nAccept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3\r\nAccept-Encoding: gzip, deflate, br\r\nAccept-Language: zh-CN,zh;q=0.9,und;q=0.8,en;q=0.7\r\nCookie: csrftoken=kzAhOkqkoPdnQuOxI7AQTa8aOmT7g6ebPiwrI0jpQ8m04NmYLkzkFvDtD8febu41; Hm_lvt_080836300300be57b7f34f4b3e97d911=1559726342,1559732417\r\n\r\n''''conn.send(b'HTTP/1.1 200 OK\r\n\r\n')'''页面显示Hello必须遵守http协议返回一个响应头'''current_path = data.decode('utf-8').split('\r\n')[0].split(' ')[1]'''/index/'''if current_path == '/index/':with open('index.html', 'rb') as f:conn.send(f.read())else:conn.send(b'404')conn.close()

第二版本

  根据HTTP传送过来的信息返回相应的页面,通过列表保存信息模拟django中的urls,通过函数返回数据模拟django中views

import socketserver = socket.socket()
server.bind(('127.0.0.1', 8000))
server.listen(5)def index():return 'index'def login():return 'login'def error():return '404'urls = [('/index/', index),
('/login/', login) ]
while True:conn, addr = server.accept()while True:data = conn.recv(1024)'''***data***b'GET /index/ HTTP/1.1\r\nHost: 127.0.0.1:8000\r\nConnection: keep-alive\r\nUpgrade-Insecure-Requests: 1\r\nUser-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36\r\nAccept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3\r\nAccept-Encoding: gzip, deflate, br\r\nAccept-Language: zh-CN,zh;q=0.9,und;q=0.8,en;q=0.7\r\nCookie: csrftoken=kzAhOkqkoPdnQuOxI7AQTa8aOmT7g6ebPiwrI0jpQ8m04NmYLkzkFvDtD8febu41; Hm_lvt_080836300300be57b7f34f4b3e97d911=1559726342,1559732417\r\n\r\n''''conn.send(b'HTTP/1.1 200 OK\r\n\r\n')'''页面显示Hello必须遵守http协议返回一个响应头'''current_path = data.decode('utf-8').split('\r\n')[0].split(' ')[1]'''/index/'''
     res = Nonefor url in urls:if url[0] == current_path:res = url[1]()breakelse:res = error()conn.send(res.encode('utf-8'))

第三版

  将其拆分成start.py   urls.py   views.py

import socket
import urlsserver = socket.socket()
server.bind(('127.0.0.1', 8000))
server.listen(5)def error():return '404'while True:conn, addr = server.accept()while True:data = conn.recv(1024)'''***data***b'GET /index/ HTTP/1.1\r\nHost: 127.0.0.1:8000\r\nConnection: keep-alive\r\nUpgrade-Insecure-Requests: 1\r\nUser-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.131 Safari/537.36\r\nAccept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3\r\nAccept-Encoding: gzip, deflate, br\r\nAccept-Language: zh-CN,zh;q=0.9,und;q=0.8,en;q=0.7\r\nCookie: csrftoken=kzAhOkqkoPdnQuOxI7AQTa8aOmT7g6ebPiwrI0jpQ8m04NmYLkzkFvDtD8febu41; Hm_lvt_080836300300be57b7f34f4b3e97d911=1559726342,1559732417\r\n\r\n''''conn.send(b'HTTP/1.1 200 OK\r\n\r\n')'''页面显示Hello必须遵守http协议返回一个响应头'''current_path = data.decode('utf-8').split('\r\n')[0].split(' ')[1]'''/index/'''res = Nonefor url in urls.urls:if url[0] == current_path:res = url[1]()breakelse:res = error()conn.send(res.encode('utf-8'))
import views
urls = [('/index/', views.index),('/login/', views.login)
]
def index():return 'index'def login():return 'login'

高级版

  使用wsgiref.simple_server的make_server配置web应用

from wsgiref.simple_server import make_server
from urls import *def run(env, response):''':param env: 请求相关的信息,一个处理好的字符串:param response:  响应相关信息:return:'''response('200 OK', [('username', 'jason'), ('password', '123')])  # 固定写法 后面列表里面一个个元祖会以响应头kv键值对的形式返回给客户端current_path = env.get('PATH_INFO')func = Nonefor url in urls:if current_path == url[0]:func = url[1]breakif func:res = func(env)else:res = error(env)return [res.encode('utf-8')]if __name__ == '__main__':server = make_server('127.0.0.1', 8080, run)server.serve_forever()
def index(env):return 'index'def login(env):return 'login'def error(env):return '404'
from views import *
urls = [('/index/', index),('/login/', login)
]

终极版

  使用jinja2对模板进行替换,对数据库进行连接

from wsgiref.simple_server import make_server
from urls import *def run(env, response):''':param env: 请求相关的信息,一个处理好的字符串:param response:  响应相关信息:return:'''response('200 OK', [('username', 'jason'), ('password', '123')])  # 固定写法 后面列表里面一个个元祖会以响应头kv键值对的形式返回给客户端current_path = env.get('PATH_INFO')func = Nonefor url in urls:if current_path == url[0]:func = url[1]breakif func:res = func(env)else:res = error(env)return [res.encode('utf-8')]if __name__ == '__main__':server = make_server('127.0.0.1', 8080, run)server.serve_forever()
import time
from jinja2 import Template
import pymysqldef index(env):return 'index'def login(env):return 'login'def get_time(env):# 先获取当前时间current_time = time.strftime('%Y-%m-%d %X')# 打开html文件读取内容返回给客户端with open(r'templates/get_time.html', 'r', encoding='utf-8') as f:data = f.read()# 因为是以r模式打开的文件,所有获取到的内容就是一堆字符串res = data.replace('@@time@@', current_time)  # 字符串的替换return resdef get_user(env):with open(r'templates/get_user.html', 'r', encoding='utf-8') as f:data = f.read()tmp = Template(data)# 将字典传递给前端页面 前端通过变量名user_dic就可以获取到该字典return tmp.render(user_dic={'name': "jason", 'password': '123'})def get_db(env):# 连接数据库 获取数据 渲染到前端页面conn = pymysql.connect(host='127.0.0.1',port=3306,user='root',password='123',database='blog',charset='utf8',autocommit=True)cursor = conn.cursor(pymysql.cursors.DictCursor)cursor.execute('select * from userinfo')user_dict = cursor.fetchall()  # [{},{},{},{}]with open(r'templates/get_db.html', 'r', encoding='utf-8') as f:data = f.read()tmp = Template(data)return tmp.render(user_dict=user_dict)def error(env):return '404 error'
from views import *urls = [('/index',index),('/login',login),('/get_time',get_time),('/get_user',get_user),('/get_db',get_db),
]
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
@@time@@
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<p>{{ user_dic }}</p>
<p>{{ user_dic.name }}</p>
<p>{{ user_dic['password'] }}</p>
<p>{{ user_dic.get('name') }}</p>
</body>
</html>

 

转载于:https://www.cnblogs.com/yuyafeng/p/10981836.html

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

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

相关文章

set_bit() 等位函数分析! \linux-1.0\linux\include\asm\bitops.h

//将addr的第nr(nr为0-31)位置值置为1; //nr大于31时&#xff0c;把高27的值做为当前地址的偏移&#xff0c;低5位的值为要置为1的位数 extern __inline__ int set_bit(int nr,int * addr) { int mask, retval; addr nr >> 5; //nr大于31时&…

使用面向对象技术创建高级 Web 应用程序

作者&#xff1a; 出处&#xff1a; 使用面向对象技术创建高级 Web 应用程序 来源:开源中国社区 作者:oschina最近&#xff0c;我面试了一位具有5年Web应用开发经验的软件开发人员。她有4年半的JavaScript编程经验&#xff0c;自认为自己具有非常优秀的JavaScript技能&#xff…

[翻译]DirectX 状态( 转)

[翻译]DirectX 状态状态 Direct3D设备使用状态来配置所有的管道处理。采样器状态通过例如定义纹理寻址方式(texture addressing)和过滤模式控制纹理采样器设置。纹理状态设置用于控制纹理如何被组合以及相互之间如何混合的多重纹理混合器。渲染状态控制大多数管道状态。 状态块…

【转载】浅谈React编程思想

React是Facebook推出的面向视图层开发的一个框架&#xff0c;用于解决大型应用&#xff0c;包括如何很好地管理DOM结构&#xff0c;是构建大型&#xff0c;快速Web app的首选方式。 React使用JavaScript来构建用户界面&#xff0c;因此可以说是一个用来构建用户界面的JavaScrip…

a.out.h 头文件分析 \linux-1.0\linux\include\linux\a.out.h

#ifndef __A_OUT_GNU_H__ #define __A_OUT_GNU_H__#define __GNU_EXEC_MACROS__#ifndef __STRUCT_EXEC_OVERRIDE__//定义执行文件结构 struct exec {unsigned long a_info; /* Use macros N_MAGIC, etc for access */unsigned a_text; /* length of text, in bytes */unsigne…

[TypeScript] vs code TSLint常见错误解决方案

TSLint是一个Typescrip{过滤}t验证工具&#xff0c;用于检测代码。 TSLint: comment must start with a space (comment-format)注释必须从一个空格开始(comment-format)也就是说//之后必须跟随一个空格。“Missing semicolon.” : “缺少分号.”,“Use the function form of \…

ios开发笔记之 线程间通信

performSelectorOnMainThread:selector:waitUntilDone: 用于线程间通信 使两个线程同步或者时异步执行。 block阻塞转载于:https://www.cnblogs.com/vincent-lu/archive/2011/11/29/2267974.html

SQL Cookbook—数字、日期

1、计算不包含最大值和最小值的均值2、把字母数字串转换为数值3、更改累计和中的值–显示存款或取款后的值4、加减日、月、年5、计算两个日期之间的天数6、确定两个日期之间的工作日数目表EMP中&#xff0c;计算BLAKE和JONES的hiredate&#xff08;聘用日期&#xff09;之间的工…

file_table.c 文件分析 linux1_0\linux\fs\file_table.c

/** linux/fs/file_table.c** Copyright (C) 1991, 1992 Linus Torvalds*/#include <linux/fs.h> #include <linux/string.h> #include <linux/mm.h>struct file * first_file; //开头文件. int nr_files 0; //文件位置为0//文件双向链表插入文…

Day 16 包 json模块和os模块

目录 包什么是包包被导入时发生的三件事包和模块的区别相对路径和绝对路径json模块OS模块列出目录下所有文件重命名文件删除文件拼接路径判断是否为文件判断是否为文件夹判断文件是否存在新建文件夹包 什么是包 包就是里一个文件夹,里面存放了多个模块,并且包会自带__init__.py…

人的左右脑

右脑支配左手、左脚、左耳等人体的左半身神经和感觉&#xff0c;而左脑支配右半身的神经和感觉&#xff0c;正如实验一所表明的&#xff0c;右视野同左脑&#xff0c;左视野同右脑相连。因为语言中枢在左脑&#xff0c;所以左脑主要完成语言的、逻辑的、分析的、代数的思考认识…

DevExpress控件使用经验总结

DevExpress控件使用经验总结 DevExpress是一个比较有名的界面控件套件&#xff0c;提供了一系列的界面控件套件的DotNet界面控件。本文主要介绍我在使用DevExpress控件过程中&#xff0c;遇到或者发现的一些问题解决方案&#xff0c;或者也可以所示一些小的经验总结。总体来讲&…

struct task_struct 结构分析 \linux-1.0\linux\include\linux\sched.h

//任务机构体&#xff0c;大小大概1024字节 struct task_struct {/* these are hardcoded - dont touch */ //硬件代码 不可被修改volatile long state; //状态标志 /* -1 unrunnable, 0 runnable, >0 stopped */ long counter; //计数long priority; //…

mysql基础14(关于mysql数据库在没有主键情况下去除重复数据办法)

关于mysql数据库在没有主键情况下去除重复数据办法 约定 表名:mat 根据 cat 字段去重 新增加主键为 id 步骤 1、为mat新增一列自增主键 alter table mat add column id int(11) PRIMARY KEY AUTO_INCREMENT; 2、根据cat字段分组&#xff0c;找到数量大于1的&#xff0c;…

ctype.h,ctype.c 结构分析 \linux-1.0\linux\include\linux\ctype

\linux-1.0\linux\include\linux\ctype.h #ifndef _LINUX_CTYPE_H #define _LINUX_CTYPE_H#define _U 0x01 /* upper */ //大写字母 #define _L 0x02 /* lower */ //小写字母 #define _D 0x04 /* digit */ //数字 #define _C 0x08 /* cntrl */ //控制按键 #define _P 0x10 …

AaronYang WCF教程目录

原创&#xff0c;讲究实践 1. 那天有个小孩教我WCF[一][1/3] 基本搭建 阅读 2013年6月27日1:29:02 2. 那天有个小孩教我WCF[一][2/3] 基本竣工 阅读 2013年6月29日01:30:22 3. 那天有个小孩教我WCF[一][3/3] 第二种代理引用服务&#xff0c;小…

plsql中文乱码 显示问号

输入sql语句select * from V$NLS_PARAMETERS查看字符集&#xff0c;查看第一行value值是否为简体中文 解决方案&#xff1a; 新增环境变量 变量名&#xff1a; NLS_LANG 变量值: SIMPLIFIED CHINESE_CHINA.ZHS16GBK 重启PL/SQL 解决 转载于:https://www.cnblogs.com/tonyzt/p/1…

第二阶段团队绩效评分

第二阶段评分结果&#xff1a; 转载于:https://www.cnblogs.com/xczd/p/11068692.html

从最大似然到EM算法浅解(转载)

http://blog.csdn.net/zouxy09/article/details/8537620#comments转载于:https://www.cnblogs.com/zhihaowang/p/10128356.html

Shanghai Barcamp

早上起来晚了&#xff0c;晚睡晚起的习惯很不好&#xff01;总是有段时间会养成这样的不好习惯&#xff0c;过一段时间又会早睡早起。总结的说&#xff0c;去了还是有不少收获的&#xff0c;而且刚好就在前一段时间看了不少关于vc和初期投资培养方面的知识&#xff0c;结果这次…