web框架
Web框架(Web framework)是一种开发框架,用来支持动态网站、网络应用和网络服务的开发.这大多数的web框架提供了一套开发和部署网站的方式,也为web行为提供了一套通用的方法. web框架已经实现了很多功能,开发人员使用框架提供的方法并且完成自己的业务逻辑,就能快速开发web应用了. 浏览器和服务器的是基于HTTP协议进行通信的. 也可以说web框架就是在以上十几行代码基础张扩展出来的, 有很多简单方便使用的方法, 大大提高了开发的效率.
wsgiref模块
最简单的Web应用就是先把HTML用文件保存好,用一个现成的HTTP服务器软件,接收用户请求,从文件中读取HTML返回.
如果要动态生成HTML,就需要把上述步骤自己来实现. 不过,接受HTTP请求、解析HTTP请求、发送HTTP响应都是苦力活,如果我们自己来写这些底层代码,还没开始写动态HTML呢,就得花个把月去读HTTP规范。
正确的做法是底层代码由专门的服务器软件实现,我们用Python专注于生成HTML文档. 因为我们不希望接触到TCP连接、HTTP原始请求和响应格式. 所以,需要一个统一的接口协议来实现这样的服务器软件,让我们专心用Python编写Web业务. 这个接口就是WSGI:Web Server Gateway Interface. 而wsgiref模块就是python基于wsgi协议开发的服务模块.
案例:
利用wsgiref模块创建一个服务端,与浏览器互动
服务端:
from wsgiref.simple_server import make_server
def application(environ, start_response):
start_response('200 OK', [('Content-Type', 'text/html')])
return [b'<h1>Hello, web!</h1>']
httpd = make_server('', 8080, application)
print('Serving HTTP on port 8000...')
# 开始监听HTTP请求:
httpd.serve_forever()
客户端:
浏览器直接访问:127.0.0.1:8080
DIY一个web框架
-文件结构树
Mysite(文件夹)
app01(文件夹)
__init__.py
models.py
views.py
templates(文件夹)
__init__.py
__init__.py
manage.py
urls.py
-models.py 文件
import pymysql
# 连接数据库
conn = pymysql.connect(host = '127.0.0.1', port = 3306, user = 'root', passwd = '', db = 'web')
# 创建游标
cur = conn.cursor()
sql = '''
create table userinfo(
id int primary key,
name varchar(32),
password varchar(32)
)
'''
cur.excute(sql)
# 提交
conn.commit()
# 关闭指针对象
cur.close()
# 关闭连接对象
conn.close()
-manage.py 启动文件
from wsgiref.simple_server import make_server
from app01.views import *
import urls
def routers():
URLpattern=urls.URLpattern
return URLpattern
def applications(environ,start_response):
path=environ.get("PATH_INFO")
start_response('200 OK', [('Content-Type', 'text/html'),('Charset', 'utf8')])
urlpattern=routers()
func=None
for item in urlpattern:
if path==item[0]:
func=item[1]
break
if func:
return [func(environ)]
else:
return [b"<h1>404!<h1>"]
if __name__ == '__main__':
server=make_server("",8889,applications)
print("server is working...")
server.serve_forever()
-urls.py 映射文件
from appo01.views import *
URLpattern = (
('/login', login),
)
-views 视图函数
import pymysql
from urllib.parse import parse_qs
def login(request):
if request.get('request_method') == 'POST':
try:
request_body_size = int(request.get('content_length',0))
except(ValueError):
request_body_size = 0
request_body = request['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')
# 连接数据库
conn = pymysql.connect(host='127.0.0.1',port= 3306,user = 'root',passwd='',db='web')
# 创建游标
cur = conn.cursor()
SQL = "select * from userinfo WHERE NAME ='%s' AND PASSWORD ='%s'"%(user,pwd)
cur.execute(SQL)
if cur.fetchone():
f=open("templates/backend.html","rb")
data=f.read()
data=data.decode("utf8")
return data.encode("utf8")
else:
print("OK456")
return b"user or pwd is wrong"
else:
f = open("templates/login.html", "rb")
data = f.read()
f.close()
return data
-login.html 登录页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>用户登录页面</title>
</head>
<body>
<h4>登录页面</h4>
<form action="" method="post">
用户名 <input type="text" name="user">
密码 <input type="text" name="pwd">
<input type="submit">
</form>
</body>
</html>