博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
12月29日学习内容整理:中间件
阅读量:7040 次
发布时间:2019-06-28

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

1、客户端和服务端的交互过程:

浏览器发送请求后,首先到达web服务端,也就是我们常说的wsgi,那django利用wsgi协议接口的wsgiref模块就是来模拟web服务端,在实际应用中web服务端就是一个专门的软件来工作,那wsgi将客户端的请求封装好(利用http协议的格式解析)后就传到了web应用端也就是Django,首先是到了中间件,经过中间件的检测以后才会传到URL和视图,经过视图函数的处理返回响应,响应还会经过中间件的检测后才会发给wsgi,经wsgi封装(利用http协议标准格式封装)再传给浏览器

2、定义:

中间件是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出。因为改变的是全局,所以需要谨慎实用,用不好会影响到性能。

 

3、Django中自带的中间件

顺序不能改变

我们可以自定义中间件放在最后,中间件其实就是类

from django.utils.deprecation import MiddlewareMixin  自定义中间件一定要引入,作为继承类

MIDDLEWARE = [    'django.middleware.security.SecurityMiddleware',    'django.contrib.sessions.middleware.SessionMiddleware',    'django.middleware.common.CommonMiddleware',    'django.middleware.csrf.CsrfViewMiddleware',    'django.contrib.auth.middleware.AuthenticationMiddleware',    'django.contrib.messages.middleware.MessageMiddleware',    'django.middleware.clickjacking.XFrameOptionsMiddleware',]

 

 

 

4、四种方法

 

(1)process_request(self,request)

》》》请求经过中间件时会依次调用每一个中间件的process_request方法,注意顺序是从上到下

》》》没有return值

》》》若加上return值,Django就会直接截断,不会再去下一个中间件检测,而是直接返回return的内容作为响应,再依次调用process_response方法(一定要注意也会经过当前中间件的process_response方法),直至浏览器,通常应用在服务端去处理一些非法的访问请求

 

(2)process_response(self,request,response)

》》》响应经过中间件时会依次调用每一个中间件的process_response方法,注意顺序是从下到上

》》》必须有return值,返回response响应

 

(3)process_view(self, request, callback, callback_args, callback_kwargs)

》》》请求经过URL控制器到达视图函数之前会依次调用每一个中间件的process_view方法,顺序是从上到下,检测完后再到视图函数进行处理

》》》参数callback,就是该请求要执行的视图函数,我们可以在process_view中直接调用视图函数执行,django为我们提供了这样一个功能

》》》参数callback_args, callback_kwargs代表视图函数的参数

》》》若有返回值,则Django还是会截断,不再继续向下执行process_view方法和视图函数,往上依次调用process_response方法同时也调用自己的

 

 

(4)process_exception(self, request, exception)

》》请求经视图函数处理时报错就会触发process_exception方法,顺序也是从下到上的,哪一个中间件有就触发哪个

》》参数exception:保存所有的错误信息

 

 

 

 

 

 

 

 

 

 

举例:自定义中间件

 

process_request和process_response方法:

from django.utils.deprecation import MiddlewareMixinfrom django.shortcuts import HttpResponseclass Md1(MiddlewareMixin):    def process_request(self,request):        print("Md1请求")     def process_response(self,request,response):        print("Md1返回")        return responseclass Md2(MiddlewareMixin):    def process_request(self,request):        print("Md2请求")        #return HttpResponse("Md2中断")    def process_response(self,request,response):        print("Md2返回")        return response
#结果 Md1请求Md2请求view函数...Md2返回Md1返回

 

 

process_view方法

from django.utils.deprecation import MiddlewareMixinfrom django.shortcuts import HttpResponseclass Md1(MiddlewareMixin):    def process_request(self,request):        print("Md1请求")        #return HttpResponse("Md1中断")    def process_response(self,request,response):        print("Md1返回")        return response    def process_view(self, request, callback, callback_args, callback_kwargs):        print("Md1view")class Md2(MiddlewareMixin):    def process_request(self,request):        print("Md2请求")        return HttpResponse("Md2中断")    def process_response(self,request,response):        print("Md2返回")        return response    def process_view(self, request, callback, callback_args, callback_kwargs):        print("Md2view")

结果

Md1请求Md2请求Md1viewMd2viewview函数...Md2返回Md1返回

 

 

process_exception方法

class Md1(MiddlewareMixin):    def process_request(self,request):        print("Md1请求")        #return HttpResponse("Md1中断")    def process_response(self,request,response):        print("Md1返回")        return response    def process_view(self, request, callback, callback_args, callback_kwargs):        # return HttpResponse("hello")        # response=callback(request,*callback_args,**callback_kwargs)        # return response        print("md1 process_view...")    def process_exception(self):        print("md1 process_exception...")class Md2(MiddlewareMixin):    def process_request(self,request):        print("Md2请求")        # return HttpResponse("Md2中断")    def process_response(self,request,response):        print("Md2返回")        return response    def process_view(self, request, callback, callback_args, callback_kwargs):        print("md2 process_view...")    def process_exception(self):        print("md1 process_exception...")

结果

Md1请求Md2请求md1 process_view...md2 process_view...view函数...Md2返回Md1返回

 

 

当视图函数出现错误时

将md2的process_exception修改如下:

def process_exception(self,request,exception):        print("md2 process_exception...")        return HttpResponse("error")

 

结果

Md1请求Md2请求md1 process_view...md2 process_view...view函数...md2 process_exception...Md2返回Md1返回

 

转载于:https://www.cnblogs.com/wanghl1011/articles/8145113.html

你可能感兴趣的文章
RequireJS学习笔记
查看>>
js中拼接HTML方式方法及注意事项
查看>>
最新版redis的安装及配置 linux系统
查看>>
MyBatis JdbcType 与Oracle、MySql数据类型对应关系详解
查看>>
【shell】shell编程(五)-读取参数
查看>>
Easyui numberbox获取焦点事件
查看>>
SpringBoot(八)-- 日志
查看>>
php的依赖注入容器
查看>>
Lua 调试库
查看>>
ARKit从入门到精通(5)-ARScnView介绍
查看>>
remmina rdp远程连接windows
查看>>
BeautifulSoup
查看>>
终于记住回车和换行cr lf的来由和含义了 -参考: http://www.cnblogs.com/me115/archive/2011/04/27/2030762.html...
查看>>
引用CSS文件到html网页里方法
查看>>
python管道pipe
查看>>
Promise原理与实现探究的一种思路
查看>>
C# WebApi+Task+WebSocket实战项目演练(四)
查看>>
PyCharm常用快捷键
查看>>
什么是MQTT协议?
查看>>
我回来了....
查看>>