Python Django中间件使用原理及流程分析


Posted in Python onJune 13, 2020

一、什么是Django中间件

Django 中间件是用来处理Django的请求request和响应response的框架级别的钩子,它是一个轻量,低级别的插件系统,用于全局范围内改变Django的输入,输出。每个中间件组件都负责做一些特定的功能。

说的直白一点是中间件就是帮我们程序员在视图函数执行之前和执行之后都可以一些额外的操作,它是一个自定义的类,类中定义了几个方法,Django框架会在请求的特定时间去执行这些方法。

二、Django中间件的定义规则

1、 自定义中间件的规则

(1)要继承MIDDLEWAREMIXIN类

from django.utils.deprecation import MiddlewareMixin

(2)要重写父类方法 

父类的五个方法(主要process_request process_response)

(1)process_request(self,request)

*主要方法。请求刚进来时,执行视图函数之前调用。(无return)

1.中间件的process_request方法是在执行视图函数之前执行的

2.当配置中间件时,会按照MIDDLEWARE的注册顺序,也就是列表的索引值,从前到后依次执行的。

3.不同中间件之间传递的request都是同一个对象。

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

*URL路由匹配成功后,执行视图函数之前调用,拿到视图函数对象,及其所有参数。(无return)

 

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

request是HttpRequest对象。
view_func是Django即将使用的视图函数。 (它是实际的函数对象,而不是函数的名称作为字符串。)
view_args是将传递给视图的位置参数的列表.
view_kwargs是将传递给视图的关键字参数的字典。 view_args和view_kwargs都不包含第一个视图参数(request)。
'''

(3)process_template_response(self,request,response)

 

*很少用。执行了render()渲染方法后调用。(有return)

(4)process_exception(self,request,exception)

 

执行视图函数中遇到异常时调用。(无return)

*该方法有两个参数:

一个是httpresponse对象

一个是视图函数产生的exception对象

这个函数只有在视图函数抛出异常才可以执行,它返回none或者httpresponse对象,如果是httpresponse对象,django将调用模板和中间件中的process_reponse方法,并将返回给浏览器,否则默认处理异常,如果返回none,则交给下一个中间件的process_exception方法来处理执行,它的执行顺序也是按照中间件注册顺序的倒序执行。

(5)process_response(self,request,response)

 

主要方法。执行视图函数结束之后有响应时调用。(有return)

返回值可以是一个NONE,或者HttpResponse对象,如果是none,继续按照django定义的向下执行,交给下个中间件处理,如果返回是Httpresponse对象,django将不执行视图函数,则直接将该对象返回给用户。

(3)将自定义中间件类添加到setting.py文件中的MIDDLEWARE配置项里

setting.py

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',

  # 自定义 在对应app内创建一个 my_middleware.py文件,然后定义类名为Middleware的中间件
  'app.my_middleware.Middleware',
]

# 白名单路径,不需要做登陆就能访问的页面
WHITE_LIST = ['/login/', '/logout/']

MIDDLEWARE是一个列表,列表中是一个个字符串,这些字符串其实是类,也就是中间件。

三、代码实现

my_middleware.py

from django.utils.deprecation import MiddlewareMixin # 导入中间间模块
from django.shortcuts import redirect # 返回页面模块
from middlewareDemo import settings # 导入白名单


class Middleware(MiddlewareMixin): # 认证中间件

  def process_request(self, request):
    """
    请求来之前判断是否已经登录
    :param request:
    :return:
    """
    white_list = settings.WHITE_LIST

    if request.path in white_list:
      return None # 如果是白名单的路径,直接跳过
    if not request.user.is_authenticated: # 获取用户是否登陆
      return redirect('/login/')
  
  def process_response(self, request, response):
    """
    不管是何执行结果,都会返回相应的HttpResonse对象
    :param request:
    :param response:
    :return:
    """
    print('m1.process_response')
    return response

  def process_exception(self, request, exception):
    """
    出现异常才会被调用进行异常处理
    :param request:
    :param exception:
    :return:
    """
    print('m1.process_exception')

四、中间件的使用场景

1.做IP限制

放在中间件类的列表中,阻止某些ip访问;

2.URL访问过滤

如果用户访问的是logo视图(放过)

如果访问其他视图,需要检测是否已经有session,已经有了放行,如果没有返回login,这样就省的在多个视图函数上写装饰器了!

3.缓存

客户端请求来了,中间件去缓存看看有没有数据,有直接返回给用户,没有再去逻辑层执行视图函数

4、CSRF

Django项目中默认启用了csrf保护,每次请求时通过CSRF中间件检查请求中是否有正确token值

五、Django中间件与装饰器的区别

1、Django 中间件:在视图函数执行之前先去进行处理,在视图函数执行之后再去进行收尾工作。不会区分是哪个视图,所有的视图统统一视同仁,都会执行之前进行处理或请求之后进行处理。

在Django创建的时候,Django默认会给我们加6个中间件。“比如session和csrf,在视图函数执行前,我们就需要对它进行处理,可以使用装饰器来做,也可以使用中间件来处理。”

2、装饰器:主要是作用域问题。如果给视图函数上面添加装饰器,它能够保证这个视图的方法在执行之前或执行之后被执行。但是它仅仅适用于哪些视图添加装饰器,那些视图会有这些作用。

如果是做一个普遍的处理,不去区分视图的话,就用middleware避免编写重复功能的代码,本质上就是一个自定义类,类中定义了几个方法,Django框架会在请求的特定的时间去执行这些方法。

可以用于登录时的黑名单验证。

如果需要对特殊视图进行处理,可以使用装饰器。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python递归删除指定目录及其所有内容的方法
Jan 13 Python
python3利用Dlib19.7实现人脸68个特征点标定
Feb 26 Python
python脚本实现验证码识别
Jun 07 Python
浅谈python实现Google翻译PDF,解决换行的问题
Nov 28 Python
对python使用telnet实现弱密码登录的方法详解
Jan 26 Python
python3实现二叉树的遍历与递归算法解析(小结)
Jul 03 Python
使用Python制作表情包实现换脸功能
Jul 19 Python
python去除删除数据中\u0000\u0001等unicode字符串的代码
Mar 06 Python
解决Django Haystack全文检索为空的问题
May 19 Python
python基于pexpect库自动获取日志信息
Feb 01 Python
解决import tensorflow导致jupyter内核死亡的问题
Feb 06 Python
python - asyncio异步编程
Apr 06 Python
Django QuerySet查询集原理及代码实例
Jun 13 #Python
Python celery原理及运行流程解析
Jun 13 #Python
基于Python实现视频的人脸融合功能
Jun 12 #Python
使用Keras实现简单线性回归模型操作
Jun 12 #Python
Python实现Keras搭建神经网络训练分类模型教程
Jun 12 #Python
简单了解Python变量作用域正确使用方法
Jun 12 #Python
keras 读取多标签图像数据方式
Jun 12 #Python
You might like
PHP 表单提交给自己
2008/07/24 PHP
Php连接及读取和写入mysql数据库的常用代码
2014/08/11 PHP
一个简单的Ext.XTemplate的实例代码
2012/03/18 Javascript
使用struts2+Ajax+jquery验证用户名是否已被注册
2016/03/22 Javascript
浅谈JS正则表达式的RegExp对象和括号的使用
2016/07/28 Javascript
同步文本框内容JS代码实现
2016/08/04 Javascript
浅谈javascript中的三种弹窗
2016/10/21 Javascript
prototype与__proto__区别详细介绍
2017/01/09 Javascript
深入理解javascript的getTime()方法
2017/02/16 Javascript
JavaWeb表单及时验证功能在输入后立即验证(含用户类型,性别,爱好...的验证)
2017/06/09 Javascript
canvas基础绘制-绚丽倒计时的实例
2017/09/17 Javascript
js前端导出Excel的方法
2017/11/01 Javascript
vue-content-loader内容加载器的使用方法
2018/08/05 Javascript
layui 上传插件 带预览 非自动上传功能的实例(非常实用)
2019/09/23 Javascript
Python3搜索及替换文件中文本的方法
2015/05/22 Python
python开发之for循环操作实例详解
2015/11/12 Python
图文讲解选择排序算法的原理及在Python中的实现
2016/05/04 Python
Django中的Model操作表的实现
2018/07/24 Python
解决python flask中config配置管理的问题
2019/07/26 Python
Django中的用户身份验证示例详解
2019/08/07 Python
python在不同条件下的输入与输出
2020/02/13 Python
Zadig&Voltaire官网:法国时装品牌
2018/01/05 全球购物
印尼极简主义和实惠的在线家具店:Fabelio
2019/03/27 全球购物
Guess荷兰官网:美国服饰品牌
2020/01/22 全球购物
2013届毕业生求职信范文
2013/11/20 职场文书
光荣入党自我鉴定
2014/01/22 职场文书
九年级英语教学反思
2014/01/31 职场文书
网络编辑岗位职责范本
2014/02/10 职场文书
求职面试个人自我评价
2014/02/28 职场文书
《鸿门宴》教学反思
2014/04/22 职场文书
保护环境倡议书300字
2014/05/19 职场文书
团队精神口号
2014/06/06 职场文书
创业计划书之酒吧
2019/12/02 职场文书
Python opencv缺陷检测的实现及问题解决
2021/04/24 Python
bootstrapv4轮播图去除两侧阴影及线框的方法
2022/02/15 HTML / CSS
解决ubuntu安装软件时,status-code=409报错的问题
2022/12/24 Servers