1. Python常用的Web开发框架
1. 企业级开发框架——Django
组成部分
1. 管理工具: 一套内置的创建站点、迁移数据
2. Modle:提供数据访问接口和模块
3. View:Django的视图层封装了HttpRequest 和Response等一系列操作和数据流
4. Template:渲染模板语言
5. 管理站:生成后台数据管理站
2. 高并发处理框架——tornado
特点
1.娲女诶的Web框架
2.高校网络库
3.搞笑的内部Http服务器
4.完备的WebSocket支持
3. 快速建站框架——Flask
面向简单需求和小型应用的微框架
4.底层自定义协议网络框架——Twisted
Python语言编写的事件驱动的网络框架,
2. Django请求的生命周期
1.wsgi,请求封装后交给web框架
2.中间件,对请求进行校验或者在请求对象中添加相关数据
3.路由匹配:根据不同url去匹配不同的视图函数
4.视图函数:在视图函数中进行业务逻辑的处理
5.中间件:对响应的数据进行处理
6.wsgi:将响应的内容发送给浏览器
3. Django中间件的方法
1. process_requet: 接收到客户端信息后立即执行
2. process_response:返回到客户端信息前最后执行
3. process_view:得到视图函数的名称
4. process_exception: 视图函数出错时执行
5. process_template_response:在视图函数执行完后立即执行,前提是视图返回的对象中有一个render()方法
3. Restufull 规范
软件架构风格
1.restful 提高了代码的复用性
2.推荐使用Https协议,让网络接口更加安全
3.在url中可以体现版本号
4.url中可以体现是否是API接口
5.url中可以添加条件去筛选匹配
6.可以根据Http不同的method,进行不同的资源操作
7.有返回值,而且格式为统一的json格式
4. DRF框架的组件
1. 序列化组件:serializers 对queryset序列化以及对请求数据格式校验
2. 路由组件routers 进行路由分发
3. 视图组件ModelViewSet 帮助开发者提供了一些类,并在类中提供了多个方法
4. 认证组件 写一个类并注册到认证类
5. 权限组件
6. 解析器
7. 渲染
8. 分页 对获取到的数据进行分页处理, pagination_class
5. jwt认证
1. 一般用于用户认证 jwt的实现原理: - 用户登录成功之后,会给前端返回一段token。
2. token是由.分割的三段组成。
- 第一段header:类型+算法+base64url加密 -
- 第二段paylod:用户信息+超时时间+base64url加密 -
- 第三段sign:hs256(前两段拼接)加密 + base64url - 以后前端再次发来信息时 - 超时验证 - token合法性校验
6. FBV、CBV
FBV:基于函数的视图
CBV:基于类的视图
1.提高了代码的复用性,可以使用面向对象的技术,比如Mixin(多继承) 2.可以用不同的函数针对不同的HTTP方法处理,
7.ORM中QuerySet对象的所有方法
1. all() 所有结果
2. filter(): 筛选条件
3.order_by(): 排序
4.reverse(): 反向排序
5.count(): 返回数据库中匹配查询(QuerySet)的对象数量。
6.first() : 第一条记录
7.last(): 最后一条记录
8.distinct(): 从返回结果中剔除重复纪录
9.exits(); 如果QuerySet包含数据,就返回True,否则返回False
10.exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
8. sql语句
from django.db import connection
cursor = connection.cursor()
cursor.execute("SELECT DATE_FORMAT(create_time, '%Y-%m') FROM blog_article;")
ret = cursor.fetchall()