我们一直都在使用中间件,只是没有注意到而已,打开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. Linux学习历程——Centos 7 mkdir命令

    一.命令介绍 mkdir 命令用于创建空白目录格式为“mkdir [选项] 目录”, 除了能够创建单个空白目录,还能结合 -p 参数来递归创建具有嵌套层叠关系的文件目录. -------------- ...

  2. AD域安装及必要设置

    本文主要介绍AD域的安装和程序开发必要的设置.   一.安装AD域 运行dcpromo命令,安装AD域. 步骤:     1.win+R     2.dcpromo 图例:           百度百 ...

  3. Vector与ArrayList区别

    1)Vector的方法都是同步的(Synchronized),是线程安全的: ArrayList的方法是线程不安全的. 由于线程同步必然会影响性能,因此,ArrayList的性能比Vector好. 请 ...

  4. ORACLESQL语句的优化

    ORACLESQL语句的优化: 选择最有效率的表名顺序:应该选择记录条数最少的表作为基表! 因为Oracle解析器的处理顺序是从右至左的.当ORACLE处理多个表时, 会运用排序及合并的方式连接它们. ...

  5. loadrunner关联及web_reg_save_param方法浅析

    一.什么是关联 关联(correlation):脚本回放过程中,客户端发出请求,通过关联函数所定义的左右边界值(也就是关联规则),在服务器所响应的内容中查找,得到相应的值,已变量的形式替换录制时的静态 ...

  6. day 10函数二

    今日内容 '''实参:调用函数,在括号内传入的实际值,值可以为常量.变量.表达式或三者的组合​*****形参:定义函数,在括号内声明的变量名,用来接受外界传来的值​'''​'''注:形参随着函数的调用 ...

  7. Linux内核入门到放弃-虚拟文件系统-《深入Linux内核架构》笔记

    VFS的任务并不简单.一方面,它用来提供了一种操作文件.目录及其他对象的统一方法.另一方面,它必须能够与各种方法给出的具体文件系统的实现达成妥协,这些实现在具体细节.总体设计方面都有一些不同之处. 文 ...

  8. 云端安装MQTT服务器

    如果自己下载的3.1版本的MQTT, 安装步骤参考 https://developer.emqx.io/docs/emq/v3/cn/install.html 配置用户名和密码第一种是用http ht ...

  9. Raft与MongoDB复制集协议比较

    在一文搞懂raft算法一文中,从raft论文出发,详细介绍了raft的工作流程以及对特殊情况的处理.但算法.协议这种偏抽象的东西,仅仅看论文还是比较难以掌握的,需要看看在工业界的具体实现.本文关注Mo ...

  10. Socket之listen() receive()

    socket.listen([backlog]) 相比listen方法,它俩就好理解多了,一个是Client用于连接Server的方法,一个是Server用于接收Client的连接申请的方法.  但事 ...