博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django生命周期,FBV,CBV
阅读量:6369 次
发布时间:2019-06-23

本文共 4307 字,大约阅读时间需要 14 分钟。

一. Django生命周期

  首先我们知道HTTP请求及服务端响应中传输的所有数据都是字符串,在Django中,当我们访问一个的url时,会通过路由匹配进入相应的html网页中。Django的请求生命周期是指当用户在浏览器上输入url到用户看到网页的这个时间段内,Django后台所发生的事情,而Django的生命周期内请求响应HTTP的过程如下:

<1> 客户端发送http请求,当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 ,请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者post,体现在url之中。

<2> 服务器接收到HTTP请求后,根据请求头中的url在路由关系表中进行匹配(从下到下)

<3> 匹配成功后,执行指定的Views函数,视图函数根据客户端的请求查询相应的数据。返回给Django,然后Django把客户端想要的数据做为一个字符串返回给客户端。

  URL >>函数      ==>FBV

  URL>>类          ==>CBV

  响应内容:响应头和响应体

<4> 客户端浏览器接收到返回的数据,经过渲染后显示给用户。

  如果同时有多个客户端同时发送不同的url到服务端请求数据,服务端查询到数据后,怎么知道要把哪些数据返回给哪个客户端呢?

  因此客户端发到服务端的url中还必须要包含所要请求的数据信息等内容,例如 http://www.aaa.com/index/?nid=user这个url中,客户端通过get请求向服务端发送的nid=user的请求,服务端可以通过request.GET.get("nid")的方式取得nid数据。 

  客户端还可以通过post的方式向服务端请求数据。当客户端以post的方式向服务端请求数据的时候,请求的数据包含在请求体里,这时服务端就使用request.POST的方式取得客户端想要取得的数据。需要注意的是,requiest.POST是把请求体的数据转换为一个字典,请求体中的数据默认是以字符串形式存在的。

二. FBV模式和CBV模式

1.FBV模式

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

示例:

/*---------------urls.py-----------------------*/from django.conf.urls import url, include# from django.contrib import adminfrom mytest import views  urlpatterns = [    # url(r‘^admin/‘, admin.site.urls),    url(r‘^index/‘, views.index),]/*------------------views.py-----------------*/from django.shortcuts import render  def index(req):    if req.method == ‘POST‘:        print(‘method is :‘ + req.method)    elif req.method == ‘GET‘:        print(‘method is :‘ + req.method)    return render(req, ‘index.html‘)
View Code

2.CBV模式

  CBV(class base views) 就是在视图里使用类处理请求。

示例:

/*----------------urls.py------------------*/from mytest import viewsurlpatterns = [    # url(r‘^index/‘, views.index),    url(r‘^index/‘, views.Index.as_view()),    #注:url(r‘^index/‘, views.Index.as_view()),  是固定用法。]/*----------------views.py---------------*/from django.views import Viewclass Index(View):    def get(self, req):        print(‘method is :‘ + req.method)        return render(req, ‘index.html‘)      def post(self, req):        print(‘method is :‘ + req.method)        return render(req, ‘index.html‘)
View Code

注意:

  使用fbv的模式,在url匹配成功之后,会直接执行对应的视图函数;而如果使用cbv模式,在url匹配成功之后,会找到视图函数中对应的类,然后这个类回到请求头中找到对应的Request Method。

如果客户端以post的方式提交请求,就执行类中的post方法;  如果客户端以get的方式提交请求,就执行类中的get方法。然后查找用户发过来的url,在类中执行对应的方法,查询生成用户需要的数据  。

总结:

<1>以get方式请求数据时,请求头里有数据,请求体里没有数据。以post请求数据时,请求头和请求体里都有数据。

<2>fbv方式请求的过程:

  用户发送url请求,Django会依次遍历路由映射表中的所有记录,一旦路由映射表其中的一条匹配成功了,就执行视图函数中对应的函数名,这是fbv的执行流程

<3>cbv方式请求的过程:

  当服务端使用cbv模式的时候,用户发给服务端的请求包含url和method,这两个信息都是字符串类型,服务端通过路由映射表匹配成功后会自动去找dispatch方法,然后Django会通过dispatch根据method值以反射的方式找到类中对应的方法(如post或者get方法)并执行类中的方法,执行完毕之后,会把客户端想要的数据返回给dispatch方法,由dispatch方法把数据返回经客户端。

<4>dispatch方法

from django.views import Viewclass CBV(View):    def dispatch(self, request, *args, **kwargs):        #由于要先经历dispatch,再执行get或post方法,故get和post方法都要执行的内容,比如日志信息,又如登录验证,都可在此处扩展        print("dispatch......")        #CBV继承父类的dispatch方法,        res=super(CBV,self).dispatch(request,*args,**kwargs)        #res是接受的父类dispatch返回的内容        return res    def get(self,request):        return render(request, "cbv.html")    def post(self,request):        return HttpResponse("cbv.get")
View Code

三. Django请求生命周期之响应内容

<1>响应内容包括响应头和响应体

<2>http提交数据的方式有"post","get","put","patch","delete","head","options","trace".

  提交数据的时候,服务端依据method的不同会触发不同的视图函数,对于form表单来说,提交数据只有get和post两种方法另外的方法可以通过Ajax方法来提交,服务端根据个人请求信息的不同来操作数据库,可以使用原生的SQL语句,也可以使用Django的ORM语句。

Django从数据库中查询处理完用户想要的数据,将结果返回给用户。从Django中返回的响应内容包含响应头和响应体,在Django中,有的时候一个视图函数,执行完成后会使用HttpResponse来返回一个字符串给客户端。这个字符串只是响应体的部分,返回给客户端的响应头的部分应该怎么设置呢???

为返回给客户端的信息加一个响应头:

示例:

from django.views import Viewclass CBV(View):    def dispatch(self, request, *args, **kwargs):        print("dispatch......")        res=super(CBV,self).dispatch(request,*args,**kwargs)        print(res)        return res    def get(self,request):        return render(request, "cbv.html")    def post(self,request):        res=HttpResponse("cbv.post")#响应体        res["h1"]='v1'        res.set_cookie("k2","v2")#响应头        res.set_cookie("k4","v4")#响应头        print("res:",res)        print("request.cookie:",request.COOKIES)        return res
View Code

打印的信息:

res: 
request.cookie: {
'csrftoken': 'jmX9H1455MYzDRQs8cQLrA23K0aCGoHpINL50GnMVxhUjamI8wgmOP7D2wXcpjHb', 'h1':'v1', k2': 'v2', 'k4': 'v4'}

 

转载于:https://www.cnblogs.com/wuxunyan/p/9148132.html

你可能感兴趣的文章
GreenPlum之日常SQL脚本笔记(二)
查看>>
python进阶-面向对象编程六:元类
查看>>
c语言知识(找出大于2门成绩不及格的学生)
查看>>
如何搭建个人的yum repository
查看>>
Ant出现"使用了未经检查或不安全的操作"
查看>>
SlipJs滚动条
查看>>
leetcode第一刷_Minimum Window Substring
查看>>
2.oracle分页,找到员工表中薪水大于本部门平均薪水的员工
查看>>
Caused by: java.lang.NumberFormatException: For input string: &quot;&quot;
查看>>
彻查网络局部网段内Ping时断时续的问题
查看>>
新公式:互联网+脑科学=互联网神经学
查看>>
第一篇,测试
查看>>
[zz]Using SyncTeX with LaTeX
查看>>
冒泡法排序参考(Java)
查看>>
Silverlight TreeView 带 checkbox和图片
查看>>
武汉科技大学ACM:1007: 不高兴的津津
查看>>
《pyhton学习手册》 第33章 异常编码细节
查看>>
条目二十三《考虑用排序的vector替代关联容器》
查看>>
Keepalived 资源监控
查看>>
VRRP协议
查看>>