Django中请求的生命周期 和 FBV模式和CBV模式

Django的生命周期就是你的 一个请求所发生的整个流程

Django的生命周期内到底发生了什么呢??

. 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端
请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者post,体现在url之中. . url经过Django中的wsgi,再经过Django的中间件,最后url到过路由映射表,在路由中一条一条进行匹配,
一旦其中一条匹配成功就执行对应的视图函数,后面的路由就不再继续匹配了.
. 视图函数根据客户端的请求查询相应的数据.返回给Django,然后Django把客户端想要的数据做为一个字符串返回给客户端.
. 客户端浏览器接收到返回的数据,经过渲染后显示给用户

首先: wsgi     -------->中间件----------->路由系统----------->视图函数------------> 模板和orm  --------------->返回给请求者

wsgi:  是web服务网关接口,一套协议

这套协议的实现是wsgi这个模块来实现 它内部封装了soccet来实现

  django中实现wsgi的模块有: wsgiref  和uwsgi模块

中间件:

路由系统就是django中的url

视图函数:就是views

模板是:template中的前端界面

orm   是你的django去操作你的数据库中的内容

Django中请求的生命周期 和 FBV模式和CBV模式

wsgi是一个协议 是http协议

CSRF_TOKEN

可以理解为 ,为了防止非法的登陆  预防黑客登陆  因为是先要get请求然后 给你的get发送一个随机字符串 然后你下一次的post请求的时候必须要带着这个随机字符串 不然就会不让你访问,

防止黑客什么的直接post来进入

FBV模式和CBV模式:

FBV: 一个url对应一个视图函数

CBV:一个url对应一个类

一个url对应一个视图函数,这个模式叫做FBV(Function Base Views)

除了FBV之处,Django中还有另外一种模式叫做CBV(Class Base views),即一个url对应一个类

我们经常写的直接定义函数的就是FBV

CBV是类的形式:但是这个类需要继承一个View 并且你的url内也的写法也不一样需要用到as_view

CBV 需要注意定义一定要继承views.View注册路由一定要写 类名.as_view()

CBV的 urls:

from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'Index/',views.Index.as_view), ]
# CBV  就是先导入views然后继承它 然后  把post和get放在两个方法中
from django import views class Index(views.View): def get(self,request): # 如果是get操作的时候
return render(request,'index.html') def post(self,request):
return HttpResponse('ok')
上一篇:Java设置PPT幻灯片背景——纯色、渐变、图片背景


下一篇:Android事件总线