一、前言

二、框架结构及实现流程

三、总结

一、前言

  当我们了解了Web应用和Web框架,以及HTTP协议的原理之后,我们可以自己动手DIY一个最简单的WEB框架,以加深对Web框架的理解,并为即将学习的Django探探路。

二、框架结构及实现流程

  1.框架结构的内容如下图所示

  我们DIY的这个Web框架按照启动的先后顺序,大致分为这样几个部分,分别是models.py、manage.py、urls.py、views.py、templates(html文件)五个部分,下面我们分别对这五个部分进行实现,最后,进行运行测试,验证框架的的可用性。

  2.实现流程

  (1) models.py -- 与数据库相关的,在我们的项目启动前,利用models.py在数据库中创建表结构,注意,仅运行一次。

#!/usr/bin/env python3
#!-*- coding:utf-8-*-
# write by cc import pymysql # 1.建立连接
conn = pymysql.connect(
host = 'localhost',
port = 3306,
user = 'cc1',
password = 'cc111',
db = 'db1',
charset = 'utf8'
) # 2.获取游标
cursor = conn.cursor()
# cursor = conn.cursor(pymysql.cursor.DictCursor) # 设游标类型为字典类型 # 3.执行sql语句
sql = "create table users(id int,user char(12),pwd char(12))"
rows = cursor.execute(sql)
print(rows) # 打印受影响的记录条数 # 4.提交(必须提交,才能实现操作)
conn.commit() # 5.关闭游标和连接
cursor.close()
conn.close()

  (2) manage.py -- 项目的启动文件

from wsgiref.simple_server import make_server

from urls import url_list

def application(environ,start_response):
path = environ.get("PATH_INFO")
print(path)
start_response("200 OK",[('Content-Type','text/html')]) func = None
for item in url_list:
if path == item[0]:
func = item[1]
break
if func:
return [func(environ)]
else:
return [b'404 Not found'] if __name__ == '__main__':
httpd = make_server("",8080,application) # 指定端口
print('Serving HTTP on port 8080...')
httpd.serve_forever() # 开启监听

  (3) urls.py -- url控制器,反映路径与视图函数的映射关系

from app01.views import *

url_list = [
('/favcion.ico',fav),
('/index',index),
('/login',login),
('/reg',reg),
('/timer',timer),
('/auth',auth)
]

  (4) views.py -- 视图函数,固定接收一个形式参数:environ

from urllib.parse import parse_qs
def fav(environ):
with open('templates/favcion.ico','rb') as f:
data = f.read()
return data def index(environ):
with open('templates/index.html','rb') as f:
data = f.read()
return data def login(environ):
with open('templates/login.html','rb') as f:
data = f.read()
return data def reg(environ):
with open('templates/reg.html','rb') as f:
data = f.read()
return data def timer(environ):
import datetime
now = datetime.datetime.now().strftime("%y-%m-%d %X")
return now.encode('utf-8') def auth(environ):
try:
request_body_size = int(environ.get('CONTENT_LENGTH',0))
except(ValueError):
request_body_size = 0
request_body = environ['wsgi.input'].read(request_body_size)
data = parse_qs(request_body) # 解析出用户输入的用户名和密码
user = data.get(b'user')[0].decode('utf8')
pwd = data.get(b'pwd')[0].decode('utf8') # 连接数据库
import pymysql
conn = pymysql.connect(host='localhost',port=3306,user='cc1',password='cc111',db='db1',charset='utf8') # 创建游标
cursor = conn.cursor() # 执行数据查询、插入等操作
sql = 'select * from users where user=%s and pwd=%s'
cursor.execute(sql,(user,pwd)) # 验证是否能取出相关记录
if cursor.fetchone():
print(cursor.fetchone())
f = open('templates/backend.html','rb')
data = f.read()
data = data.decode('utf8')
return data
else:
return b'user or password is wrong'

  (5) templates -- 储存 html 文件,当用户输入的路径正确存在与url控制器中时,为用户展示指定的页面。

  favcion.ico 是一个缩略图,可自由指定。

  index.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页</title>
</head>
<body>
<h1>Hello world!</h1>
<h2>Boys and girls!</h2>
<h3><a href="https://www.cnblogs.com/schut"/>This is my web</a></h3>
<img src="https://pic.cnblogs.com/avatar/1209144/20170813234607.png">
</body>
</html>

  login.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>登录</title>
</head>
<body>
<h1>Hello world!</h1>
<h2>Boys and girls!</h2>
<form action="http://127.0.0.1:8080/auth" method="post">
姓名<input type="text" name="user">
密码<input type="password" name="pwd">
<input type="submit">
</form>
</body>
</html>

  reg.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>注册页面</title>
</head>
<body>
<h3>欢迎来到注册页面</h3>
<form action="" method="post">
用户名:<input type="text" name="username"><br/>
密 码:<input type="password" name="pwd"><br/>
再次输入密码:<input type="password" name="pwd2"><br/>
<input type="submit">
<input type="reset">
</form>
</body>
</html>

  backend.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>index</title>
</head>
<body>
<h2>欢迎登录</h2>
</body>
</html>

三、总结

  以上DIY的简易框架,大致可以分为五个部分,各自承担不同的作用,缺一不可。

manage.py -- 启动文件,封装socket

1   urls.py -- 路径与视图函数的映射关系 ------------- url控制器
2 views.py -- 视图函数,固定接收一个形式参数:environ ------- 视图函数
3 templates文件夹 -- html文件 -------模板
4 models --在项目启动前,在数据库中创建表结构 ----- 与数据库相关

  

DIY一个Web框架的更多相关文章

  1. 2、基于wsgiref模块DIY一个web框架

    一 web框架 Web框架(Web framework)是一种开发框架,用来支持动态网站.网络应用和网络服务的开发.这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方 ...

  2. 第一个web框架tornado

    简介 tornado,是我学到的第一个web框架是 FriendFeed 使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py 或者 Google ...

  3. Go语言笔记[实现一个Web框架实战]——EzWeb框架(一)

    Go语言笔记[实现一个Web框架实战]--EzWeb框架(一) 一.Golang中的net/http标准库如何处理一个请求 func main() { http.HandleFunc("/& ...

  4. 手把手和你一起实现一个Web框架实战——EzWeb框架(二)[Go语言笔记]Go项目实战

    手把手和你一起实现一个Web框架实战--EzWeb框架(二)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 上一篇文章我们实现了框架的雏形,基本地 ...

  5. 手把手和你一起实现一个Web框架实战——EzWeb框架(三)[Go语言笔记]Go项目实战

    手把手和你一起实现一个Web框架实战--EzWeb框架(三)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 本篇代码,请选择demo3 这一篇文章 ...

  6. 手把手和你一起实现一个Web框架实战——EzWeb框架(四)[Go语言笔记]Go项目实战

    手把手和你一起实现一个Web框架实战--EzWeb框架(四)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 这一篇文章主要实现路由组功能.实现路由 ...

  7. 手把手和你一起实现一个Web框架实战——EzWeb框架(五)[Go语言笔记]Go项目实战

    手把手和你一起实现一个Web框架实战--EzWeb框架(五)[Go语言笔记]Go项目实战 代码仓库: github gitee 中文注释,非常详尽,可以配合食用 本篇代码,请选择demo5 中间件实现 ...

  8. Python高级网络编程系列之终极篇---自己实现一个Web框架

    通过前面几个小节的学习,现在我们想要把之前学到的知识点给串联起来,实现一个很小型的Web框架.虽然很小,但是用到的知识点都是比较多的.如Socket编程,装饰器传参在实际项目中如何使用.通过这一节的学 ...

  9. luci框架-LUA的一个web框架使用

    转自:http://blog.csdn.net/initphp/article/details/17527639 LUCI 这个在百度上搜索除了一篇我的百度文库 luci 的介绍文章之外,前三页都是些 ...

随机推荐

  1. K8S组件

    Master 组件 Master组件提供集群的管理控制中心.Master组件可以在集群中任何节点上运行.但是为了简单起见,通常在一台VM/机器上启动所有Master组件,并且不会在此VM/机器上运行用 ...

  2. 2015-2016-2《Java程序设计》团队博客5

    一.项目进展 本周将所有的项目代码全部进行了汇总总结,归纳在了一起,进行整体的测试.虽然在编写的时候很顺利,也就是片段代码问题不大,但是汇总到一起时还是产生了冲突与不对等的问题,所以我们只能仔细地从细 ...

  3. 【大数据作业十一】分布式并行计算MapReduce

    作业要求:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE2/homework/3319 1.用自己的话阐明Hadoop平台上HDFS和MapReduce的功 ...

  4. linux hexdump使用

    # hexdump -h hexdump: invalid option -- 'h' Usage: hexdump [options] file... Options: -b one-byte oc ...

  5. 使用yarn代替npm作为node.js的模块管理器

    使用yarn代替npm作为node.js的模块管理器 转 https://www.jianshu.com/p/bfe96f89da0e     Fast, reliable, and secure d ...

  6. 案例:使用BeautifuSoup4的爬虫

    使用BeautifuSoup4解析器,将招聘网页上的招聘单位名称存储出来.其他信息可类似爬取即可 # -*- coding:utf-8 -*- from bs4 import BeautifulSou ...

  7. Linux MySQL 5.6.43 安装

    [注意] 1.首先安装在默认目录 /usr/local/mysql,如需更改数据存储目录,进行2.3两步 2.如果需要修改数据目录,将my.nf 中的 datadir=/usr/local/mysql ...

  8. Mysql关键字之Group By(一)

    原文地址,优先更新https://hhe0.github.io group by 是一个我们在日常工作学习过程中经常遇到的一个Mysql关键字.现总结其用法如下,内容会不断补充,出现错误欢迎批评指正. ...

  9. 全基因组关联分析(GWAS)的计算原理

    前言 关于全基因组关联分析(GWAS)原理的资料,网上有很多. 这也是我写了这么多GWAS的软件教程,却从来没有写过GWAS计算原理的原因. 恰巧之前微博上某位小可爱提问能否写一下GWAS的计算原理. ...

  10. [LeetCode] 326. Power of Three 3的次方数

    Given an integer, write a function to determine if it is a power of three. Follow up:Could you do it ...