我们一直都在使用中间件,只是没有注意到而已,打开Django项目的Settings.py文件,看到下面的MIDDLEWARE配置项,django默认自带的一些中间件:

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',
'utils.middlewares.MD1',
'utils.middlewares.MD2'
]

我们之前已经接触过一个csrf相关的中间件了?我们一开始让大家把他注释掉,再提交post请求的时候,就不会被forbidden了,后来学会使用csrf_token之后就不再注释这个中间件了。

 中间件可以定义五个方法,分别是:(主要的是process_request和process_response)

  • process_request(self,request)
  • process_view(self, request, view_func, view_args, view_kwargs)
  • process_template_response(self,request,response)
  • process_exception(self, request, exception)
  • process_response(self, request, response)

  以上方法的返回值可以是None或一个HttpResponse对象,如果是None,则继续按照django定义的规则向后继续执行,如果是HttpResponse对象,则直接将该对象返回给用户。

  当用户发起请求的时候会依次经过所有的的中间件,这个时候的请求时process_request,最后到达views的函数中,views函数处理后,在依次穿过中间件,这个时候是process_response,最后返回给请求者。

      

上述截图中的中间件都是django中的,我们也可以自己定义一个中间件,我们可以自己写一个类,但是必须继承MiddlewareMixin

from django.utils.deprecation import MiddlewareMixin
class MD1(MiddlewareMixin):
def process_request(self,request):
print(id(request))
print('from MD1 process_request')
# return HttpResponse("HHHHH")
# return None def process_response(self,request,response):
# print(id(response))
print('from MD1 process_response')
return response
#----------------------------------------------------
class MD2 (MiddlewareMixin):
def process_request(self, request):
# print(id(request))
print('from MD2 process_request') def process_response(self, request, response):
# print(id(response))
print('from MD2 process_response')
return response
  • 执行时间:在视图函数执行之后
  • 参数:request -->>  与视图函数中的是同一个 /response-->>视图函数中传递的响应对象
  • 执行顺序:按照注册顺序,倒叙执行
  • 返回值:HttpResponse对象:必须是响应对象

process_view

process_view(self, request, view_func, view_args, view_kwargs)

执行时间:在process_request方法之后,在视图函数执行之前

​ 参数:

  • request -->> 跟视图函数中的是同一个
  • ​ view_func -->>  视图函数
  • ​ view_args -->> 视图函数的位置参数
  • view_kwargs-->> 视图函数的关键字参数

​ 执行顺序:按照注册顺序 顺序执行

​ 返回值:None: 正常流程

​ HttpResponse对象:不执行后面中间中的process_view方法,不执行视图函数,直接执行最后一个中间件中的process_response方法,后面正常走

from django.utils.deprecation import MiddlewareMixin
class MD1(MiddlewareMixin):
def process_request(self,request):
print(id(request))
print('from MD1 process_request')
# return HttpResponse("HHHHH")
# return None def process_response(self,request,response):
# print(id(response))
print('from MD1 process_response')
return response def process_view(self,request,view_func,view_args,view_kwargs):
# print(view_func)
# print(view_args)
# print(view_kwargs)
print('from MD1 process_view')
# return HttpResponse('kkkkkk') def process_exception(self,request,exception):
print ('from MD1 process_exception')
print(exception)
#-------------------------------------------------------------------------
class MD2 (MiddlewareMixin):
def process_request(self, request):
# print(id(request))
print('from MD2 process_request') def process_response(self, request, response):
# print(id(response))
print('from MD2 process_response')
return response def process_view(self,request,view_func,view_args,view_kwargs):
# print(view_func)
# print(view_args)
# print(view_kwargs)
print('from MD2 process_view') def process_exception(self, request, exception):
print('from MD2 process_exception')
print(exception)
# return HttpResponse('SSSSSS')

print(id(request))
print('from MD1 process_request')

print('from MD1 process_response')
print('from MD1 process_view')
print ('from MD1 process_exception')
print('from MD2 process_request')
print('from MD2 process_response')
print('from MD2 process_view')

print('from MD2 process_exception')
print(exception)

############################
72452584
from MD1 process_request

from MD2 process_request
from MD1 process_view
from MD2 process_view
from MD2 process_response
from MD1 process_response

      

process_template_response(self,request,response)

#除此之外还需在setting.py文件中进行注册
class LoginMD(MiddlewareMixin):
white_lst = ['/login/',] #白名单
black_lst = ['/black/',] #黑名单 def process_request(self,request):
return_url = request.path_info #黑名单限制访问
if return_url in self.black_lst:
return HttpResponse('This is an illegal URL ')
#白名单或者登录用户不做限制
elif return_url in self.white_lst or request.session.get('user'):
return None
else:
return redirect('/login/?return_url={}'.format(return_url))

python Django 中间件介绍的更多相关文章

  1. django中间件介绍

    在学习django中间件之前,先来认识一下django的生命周期,如下图所示: django生命周期:浏览器发送的请求会先经过wsgiref模块处理解析出request(请求数据)给到中间件,然后通过 ...

  2. Python Django 中间件

    在http请求 到达视图函数之前   和视图函数return之后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 中间件的执行流程 1.执行完所有的request方法 到达视图函数. ...

  3. Python - Django - 中间件 process_template_response

    process_template_response(self, request, response) 有两个参数,response 是 TemplateResponse 对象(由视图函数或者中间件产生 ...

  4. Python - Django - 中间件 process_exception

    process_exception(self, request, exception) 函数有两个参数,exception 是视图函数异常产生的 Exception 对象 process_except ...

  5. Python - Django - 中间件 process_view

    process_view 的执行顺序也是按照 settings.py 中的顺序来执行 process_view 在 urls.py 的对应关系之后,在执行视图函数之前执行 如果返回 None,则继续执 ...

  6. Python - Django - 中间件 process_response

    process_response 函数是执行完 views.py 后执行的函数 process_response 函数有两个参数,一个是 request,一个是 response,response 是 ...

  7. Python - Django - 中间件 process_request

    process_request 函数是中间件在收到 request 请求之后执行的函数 该函数的执行顺序是按照 settings.py 中中间件的配置顺序执行的 如果该函数返回 None,继续执行后面 ...

  8. python/ Django之中间件

    python/ Django之中间件 一.中间件 中间件共分为: (1)process_request(self,request) (2)process_view(self, request, cal ...

  9. {Django基础九之中间件} 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证

    Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学会了 ...

随机推荐

  1. MongoDB的导入与导出

    一.导入与导出可以操作本地的mongodb也可以是远程的mongodb,通用选项: -h host 主机 --port port 端口 -u username 用户名 -p password 密码 如 ...

  2. 英语词性系列-B02-动词

    诗Poem 要求:背诵这首诗,翻译现代文,根据现代文用简单的英文翻译. 动词直观体会 动词 动词 动词 动词 动词 sell卖 buy买 beat击打 look看 dance跳舞 sing唱歌 spe ...

  3. 深入Ambari Metrics 机制分析

    0.简介 Ambari作为一款针对大数据平台的运维管理工具,提供了集群的创建,管理,监控,升级等多项功能,目前在业界已经得到广泛使用. Ambari指标系统( Ambari Metrics Syste ...

  4. Java base64转图片

    import sun.misc.BASE64Decoder; import java.io.FileOutputStream; import java.io.OutputStream; public ...

  5. python3 二分法查找

    '''二分法查找有序列表掐头去尾取中间查找列表中xx在不在列表中,在,则返回索引值'''# lst = [1, 4, 6, 8, 9, 21, 23, 26, 35, 48, 49, 54, 67, ...

  6. EF Core 多对多配置

    1.配置2个数据表 T_Authors ,T_Books 2.新建控制台项目,安装EF驱动 PM> Install-Package Pomelo.EntityFrameworkCore.Mysq ...

  7. .net core 的图片处理及二维码的生成及解析

    写代码这事,掐指算来已经十有余年. 从html到css到javascript到vbscript到c#,从兴趣到职业,生活总是失落与惊喜并存. 绝大部分时候,出发并不是因为知道该到哪里去,只是知道不能再 ...

  8. Golang 入门系列(五)GO语言中的面向对象

    前面讲了很多Go 语言的基础知识,包括go环境的安装,go语言的语法等,感兴趣的朋友可以先看看之前的文章.https://www.cnblogs.com/zhangweizhong/category/ ...

  9. richedit缩放

    本程序下载地址: 要使文本在richedit控件上进行放大缩小,可以通过设置字体的大小,从而来达到缩放文本的目的. 下面是一个例子:通过调整滚动条,从而控制richedit文本缩放. 程序运行结果如下 ...

  10. Luogu P5280 [ZJOI2019]线段树

    送我退役的神题,但不得不说是ZJOIDay1最可做的一题了 先说一下考场的ZZ想法以及出来后YY的优化版吧 首先发现每次操作其实就是统计出增加的节点个数(原来的不会消失) 所以我们只要统计出线段树上每 ...