web框架
web框架本质上可以看成是一个很强大的socket服务端,用户的浏览器可以看成是拥有可视化界面的socket客户端,两者通过网络请求实现数据交互,也可以从框架层面上先简单的将web框架看成是对前端、数据库的全方位整合
web手敲框架步骤
1.搭建socket服务端
import socket
server = socket.socket() #TCP UDP
server.bind(('127.0.0.1' , 8080))
server.listen(5)
while True:
sock , addr = server.accept()
data = sock.recv(1024)
sock.send(b'hello jason')
2.浏览器发送请求
# 服务端响应的数据需要符合HTTP响应格式
sock.send(b'HTTP1.1 200 ok\r\n\r\n hello jason')
3.路由对应响应
#将客户端请求相关数据先转成字符串
data_str = data.decode('utf8')
# 采用字符串切割获取路经
current_path = data_str.split('')[1]
# 后缀的不同返回不同的内容
if current_path='/login':
sock.send(b'hello jason login!!!')
elif current_path == '/register':
sock.send(b'hello jason register')
else:
sock.send(b'404 jason error')
总结
"""
手敲框架缺陷:
1.socket代码过于重复(每次搭建服务端都需要反复造轮子)
2.针对HTTP请求数据没有完善的处理方式(目前只能定向切割)
"""
基于wsgire模块
1.模块封装功能
from wsgiref import simple_server
def run(request,response):
"""
:param request: 请求相关的数据
:param response: 响应相关的数据
:return: 返回给客户端的展示数据
"""
response('200 ok ',[])# 固定编写的代码
return [b'hello jason']
if __name__ == '__main__':
server = simple_server.make_server('127.0.0.1', 8080,run)
# 监听本机8080端口,一旦有请求访问,自动触发run方法执行
server.serve_forever()
# 模块封装了socket代码并将请求数据处理成诸多k:v键值对
2.路由对应响应
# run函数体中添加下列代码
current_path = request.get("PATH_INFO")
if current_path == '/login':
return [b'hello login html']
elif current_path == '/register':
return [b'hello register html']
return [b'404 error']
3.路由拆分流程
1.当有很多路由和响应的情况下无限制编写if判断语句,应该设置对应关系并动态调用
def register(request):
return 'register'
def login(request):
return 'login'
def error(request):
with open(r'templates/error.html', 'r', encoding='utf8') as f:
return f.read()
urls = (
('/login',login),
('/register',register)
)
def run(request, response):
func_name = None
for url_tuple in urls:
if current_path == url_tuple[0]:
# 先获取对应的函数名
func_name = url_tuple[1]
# 一旦匹配上了 后续的对应关系就无需在循环比对了
break
# for循环运行完毕之后 func_name也有可能是None
if func_name:
res = func_name(request)
else:
res = error(request) # 顺手将request也传给函数 便于后续数据的获取
return [res.encode('utf8')]
动静态网页
动态网页
页面数据来源于后端
静态网页
页面数据直接写死
1.访问某个网址后缀 后端代码获取当前时间 并将该时间传到html文件上再返回给浏览器展示给用户看
读取html内容(字符串类型) 然后利用字符串替换 最后再返回给浏览器
2.将字典传递给页面内容 并且在页面上还可以通过类似于后端的操作方式操作该数据
模板语法>>>:jinja2模块
jinja2模块
jinja2能够让我们在html文件内使用类似后端的语法来操作各种数据
jinja2下载
jinja2是第三方模块,需先下载
# cmd命令行终端:
pip install jinja2
# pycharm:
Jinja2 3.1.2
jinja使用
#【views.py】:
from jinja2 import Template
def get_dict_func(request):
d1 = {'name': 'jason', 'age': 18,'l1':[11,22,33]}
with open(r'templates/get_dict.html', 'r', encoding='utf8')as f:
data = f.read()
# 把页面数据交给模板方法处理
temp_obj = Template(data)
# 给页面传递一个键是dict,值是上面字典名称的字典过去
res = temp_obj.render({'dict': d1})
return res
'这样页面上就可以通过'dict'操作d1字典'
——————————————————————————————————————————————————————
#页面上就可以用以下方法去操作页面:
<h1>{{ dict }}</h1>
<p>{{ dict.name }}</p>
<p>{{ dict['age'] }}</p>
<p>{{ dict.get('age') }}</p>
#还可以用for循环 如以下6)中例子
{% for i in user_list %}
<tr>
<td>{{ i.id }}</td>
<td>{{ i.name }}</td>
<td>{{ i.age }}</td>
</tr>
{% endfor %}
前端、后端、数据库连接
需求:前端浏览器访问一个页面, 后端连接数据库查询user表,把每条数据传递到html页面并弄好样式然后发送给浏览器展示(把数据库user表里的内容用for循环展示在页面中)
#【cmd中创建user表】:
+----+-------+------+
| id | name | age |
+----+-------+------+
| 1 | jason | 18 |
| 2 | torry | 20 |
| 3 | jack | 22 |
+----+-------+------+
#【views.py】
import pymysql
from jinja2 import Template
def get_user_func(request):
# 连接数据库操作数据
conn = pymysql.connect(
user='root',
password='123',
host='127.0.0.1',
port=3306,
database='db1',
charset='utf8',
autocommit=True
)
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
sql1 = "select * from user"
cursor.execute(sql1)
user_data = cursor.fetchall() # [{},{},{}]
with open(r'templates/get_user.html', 'r', encoding='utf8')as f:
data = f.read()
temp_obj = Template(data)
res = temp_obj.render({'user_list': user_data})
return res
#【urls.py】
from views import *
urls = [
('/get_user',get_user_func),
]
<!--【templates目录中的get_user.html】-->
<body>
<div class="container">
<div class="row">
<h1 class="text-center">数据展示</h1>
<div class="col-md-8 col-md-offset-2">
<table class="table table-hover table-striped">
<thead>
<tr>
<th>ID</th>
<th>Name</th>
<th>Age</th>
</tr>
</thead>
<tbody>
{% for i in user_list %}
<tr>
<td>{{ i.id }}</td>
<td>{{ i.name }}</td>
<td>{{ i.age }}</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
</body>
#【启动文件】
from wsgiref.simple_server import make_server
from urls import urls
from views import *
def run(request, response):
response('200 OK', []) # 固定格式(响应头等数据)
path_info = request.get('PATH_INFO') # 获取大字典中的值(后缀名)
func_name = None # 用来存储匹配成功后的函数名
for i in urls: # ('/后缀',函数名)
if path_info == i[0]:
func_name = i[1]
break
if func_name:
res = func_name(request)
else:
res = errors_func(request)
return [res.encode('utf8')]
if __name__ == '__main__':
# 实时监听地址,当有请求过来自动给第三个三处加括号并传参调用
server = make_server('127.0.0.1', 8080, run)
# 启动服务端
server.serve_forever()
python主流web框架
1.django
大而全 自身自带的功能组件非常的多 类似于航空母舰
2.flask
小而精 自身自带的功能组件非常的少 类似于游骑兵
几乎所有的功能都需要依赖于第三方模块
3.tornado
异步非阻塞 速度极快效率极高甚至可以充当游戏服务端
ps:sanic、fastapi...
django基本使用
1.下载
pip3 install django 默认最新版
pip3 install django==版本号 指定版本
pip3 install django==2.2.22
pip下载模块会自动解决依赖问题(会把关联需要用到的模块一起下了)
2.验证
django-admin
3.常见命令
1.创建django项目
django-admin startproject 项目名
2.启动django项目
cd 项目名
python38 manage.py runserver ip:port
4.pycharm自动创建django项目
会自动创建templates文件夹 但是配置文件中可能会报错
os.path.join(BASE_DIR,'templates')
django app的概念
django类似于是一所大学 app类似于大学里面的各个学院
django里面的app类似于某个具体的功能模块
user app 所有用户相关的都写在user app下
goods app 所有商品相关的都写在goods app下
命令行创建应用
python38 manage.py startapp 应用名
pycharm创建应用
新建django项目可以默认创建一个 并且自动注册
"""
创建的app一定要去settings.py中注册
INSTALLED_APPS = [
'app01.apps.App01Config',
'app02'
]
"""
django 主要目录结构
django项目目录名
django项目同名目录
settings.py 配置文件
urls.py 存储网址后缀与函数名对应关系(不严谨)
wsgi.py wsgiref网关文件
db.sqlite3文件 django自带的小型数据库(项目启动之后才会出现)
manage.py 入口文件(命令提供)
应用目录
migrations目录 存储数据库相关记录
admin.py django内置的admin后台管理功能
apps.py 注册app相关
models.py 与数据库打交道的(非常重要)
tests.py 测试文件
views.py 存储功能函数(不严谨)
templates目录 存储html文件(命令行不会自动创建 pycharm会)
配置文件中还需要配置路径
[os.path.join(BASE_DIR,'templates'),]
"""
网址后缀 路由
函数 视图函数
类 视图类
重要名词讲解
urls.py 路由层
views.py 视图层
models.py 模型层
templates 模板层
"""
django三板斧
from django.shortcuts import
render,HttpResponse,redirect
HttpResponse
返回字符串类型的数据
render
返回html页面并且支持传值
redirect
重定向
标签:name,py,request,server,django,user,Django,初始
From: https://www.cnblogs.com/wwssadadbaba/p/16972054.html