1.中间件,在其它程序中,有的叫管道,有的叫http handler。下面是原生的中间件

2.自己也可以写中间件

2.1 写中间件,新建文件夹Middle,新建m1.py

2.2 在setting里注册中间件,1个类就是1个中间件

2.3 做测试,看是否所有的请求过来时,都必须一一经过中间件。(写了一个test函数)

运行结果:说明test请求经过了所有的中间件,打印出001,002,003以后,才打印出no money.

2.4 当想拿返回值的时候,可以通过response函数。request里面存放的是客户端的所有数据,可以有request.GET,request.POST,request.method等方法。

m1.py

from django.utils.deprecation import MiddlewareMixin

class Row1(MiddlewareMixin):
def process_request(self,request):
print('001')
def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003')
def process_response(self,request,response):
print('第1个拿到返回值的人')
return response

运行test函数,打印结果:

2.5通过第一个中间件的时候,就可以判断一下,是否携带了请求头(CSRFtoken),如果没有带请求头的话,在第1步就可以终止了。

完善我们自己写的中间件。其实中间件就是一个普通的类。

m1.py

from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001')
def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
return HttpResponse('你回去吧')
def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003')
def process_response(self,request,response):
print('第1个拿到返回值的人')
return response

运行结果:

3. 整个请求的流程如下:1.10版本,到哪个中间件发生了阻断,就从哪个中间件返回。

注意process_request, process_response 2个函数名是写死的,不能变。

4. 加上process_view后,请求的整个流程就有了变化。

m1.py

from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤1') def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
#return HttpResponse('你回去吧') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤2') def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003') def process_view(self, request, view_func, view_func_args, view_func_kwargs):
print('张欣彤3') def process_response(self,request,response):
print('第1个拿到返回值的人')
return response

结果:

请求流程:

5. 解析process_view函数的意义

def process_view(self,request,view_func,view_func_args,view_func_kwargs):
view_func:指的就是URL中对应的那个函数,在这里指test函数
view_func_args:对应test函数中接收的参数,对应的URL如下:url(r'^test/(\d+)$', views.test), def test(request,nid)
view_func_kwargs:对应test函数中接收的字典,对应的URL如下:url(r'^test/(?P<nid>\d+)$', views.test), def test(request,nid)
流程更新如下:

6. def process_exception(self,request,exception): 这个函数一般情况下不执行,只有在出错时才执行。指的是异常信息

7. def process_template_response (self,request,response):  默认情况下也不执行,

如果views中的函数返回的对象中,具有render方法,那这个函数就会执行了。

如下示例:因为有render方法,所以函数确实执行了。

函数粘贴:

urls.py

from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/$', views.login),
url(r'^index/$', views.index),
url(r'^logout/$', views.logout),
url(r'^test/(\d+)$', views.test),
]

views.py

from django.shortcuts import render,HttpResponse,redirect
# Create your views here.
def login(request):
if request.method=='GET':
return render(request,'login.html')
elif request.method=='POST':
user=request.POST.get('user')
pwd=request.POST.get('pwd')
if user=='root' and pwd=='123':
#生成随机字符串,写到浏览器cookie中,保存在session中。在随机字符串对应的字典中设置相关内容...
# 在session里面设置值
request.session['username']=user
request.session['is_login']=True
if request.POST.get('remember',None)=='1':
#设置超时时间
request.session.set_expiry(10)
return redirect('/index/')
else:
return render(request,'login.html')
def index(request):
#获取当前用户的随机字符串
#根据随机字符串获取对应的信息
#去session中获取值,如果登录成功,显示用户名
if request.session.get('is_login',None):
#return HttpResponse(request.session['username'])
return render(request,'index.html',{'username':request.session['username']})
else:
return HttpResponse('滚')
def logout(request):
request.session.clear()
return redirect('/login/') class Foo:
def render(self):
return HttpResponse('OK') def test(request,nid):
print('no money')
return Foo()
#return HttpResponse('OK')

m1.py

from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse class Row1(MiddlewareMixin):
def process_request(self,request):
print('001') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤1') def process_response(self,request,response):
print('第3个拿到返回值的人')
return response class Row2(MiddlewareMixin):
def process_request(self,request):
print('002')
#return HttpResponse('你回去吧') def process_view(self,request,view_func,view_func_args,view_func_kwargs):
print('张欣彤2') def process_response(self,request,response):
print('第2个拿到返回值的人')
return response class Row3(MiddlewareMixin):
def process_request(self,request):
print('003') def process_view(self, request, view_func, view_func_args, view_func_kwargs):
print('张欣彤3') def process_response(self,request,response):
print('第1个拿到返回值的人')
return response def process_template_response(self,request,response):
#如果views中的函数返回的对象中,具有render方法,那这个函数就会执行了。
print('----template-----response----')
return response

process_Request, 发出请求

process_view, 通过以后,就会达到view函数

process_response, 开始返回。

最新文章

  1. SQL中select与set的区别-转载
  2. [tmp] hu60@所有人插件
  3. ABAP宏--Macros
  4. Android Studio tips2
  5. 前端见微知著JavaScript基础篇:你所不知道的apply, call 和 bind
  6. 在CentOS 7 上搭建LAMP
  7. MSYS2 安装和配置
  8. ASP.NET MVC- Area 使用
  9. MongoDB入门三步曲1--安装、基本操作
  10. java学习一目了然&mdash;&mdash;异常必知
  11. 【Eclipse】Failed to load JavaHL Library
  12. IOS多线程加锁
  13. java反射机制(2)
  14. onmousedown活用之碰撞效果
  15. Django—urls系统:urls基础
  16. JavaScript根据经纬度获取距离信息
  17. Linux 桌面玩家指南:11. 在同一个硬盘上安装多个 Linux 发行版以及为 Linux 安装 Nvidia 显卡驱动
  18. X-Pack for the Elastic Stack [6.2] &#187; Securing the Elastic Stack &#187;Setting Up User Authentication
  19. 02-centOS6.7安装
  20. 【RL前沿】深度强化学习的最新进展 by 2017.12.12

热门文章

  1. 使用Chrome控制台进行3D模型编辑的尝试
  2. Unity中容易被忽略的小技巧
  3. 使用FFMPEG 压缩png图片 与tinypng压缩结果对比
  4. linux安装nginx并配置负载均衡
  5. sprint2(第四天)
  6. java 框架 面试 2
  7. mabatis报错 Result Maps collection already contains value for gamedataserver.dao.one.ChargeRecordMapper.BaseResultMap
  8. 2016011998+sw
  9. 用jar包运行带GUI的java游戏
  10. Tensorflow踩坑之tf.nn.bidirectional_dynamic_rnn()报错 “ValueError: None values not supported.”