zoukankan      html  css  js  c++  java
  • Django的中间件

      中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出。因为改变的是全局,所以需要谨慎实用,用不好会影响到性能。 
    每个中间件都会负责一个功能,例如,AuthenticationMiddleware,与sessions处理相关。

    激活中间件

    在django项目的settings模块中,有一个 MIDDLEWARE_CLASSES 变量,其中每一个元素就是一个中间件,如下图。

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

     

    中间件中可以定义四个方法,分别是:

    • process_request(self,request)
    • process_view(self, request, callback, callback_args, callback_kwargs)
    • process_exception(self, request, exception)
    • process_response(self, request, response)

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

    中间的顺序

    一般我们我们从浏览器发出一个请求 Request,得到一个响应后的内容 HttpResponse ,这个请求传递到 Django的过程如下,process request 和 process response的执行顺序正好相反,如下图所示:

    也就是说,每一个请求都是先通过中间件中的 process_request 函数,这个函数返回 None 或者 HttpResponse 对象,如果返回前者,继续处理其它中间件,如果返回一个 HttpResponse,就处理中止,返回到网页上。

    自定义中间件:

    class MyMIddleWare(object):
          
        def process_request(self,request):
            pass
        def process_view(self, request, callback, callback_args, callback_kwargs):
    
            pass
        def process_exception(self, request, exception):
            pass
          
        def process_response(self, request, response):
            return response

    注册中间件:

    自定义完成之后,需要在settings的MiddleWare中注册一下,才能被应用

    假设自定义中间件的路径是mymiddleware/auth/MIddleWare

    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',
      'mymiddleware.auth.MIddleWare.MyMIddleWare'
    ]
     

    常用的几个中间件组件:


    1. Sessions 
    2. Authentication 
    3. CSRF Protection 
    4. GZipping
    Content

    示例:

    假设我们要做一个网站的流量统计
    定义中间件
    class BlockedIpMiddleware(object):
        def process_request(self, request):
              ...数据库拿access值
              access = access+1
              ...存起来,类似这个原理        

    注册中间件

     1  MIDDLEWARE = [
     2      'mymiddleware.auth.MIddleWare.BlockedIpMIddleWare'
     3       'django.middleware.security.SecurityMiddleware',
     4       'django.contrib.sessions.middleware.SessionMiddleware',
     5       'django.middleware.common.CommonMiddleware',
     6       'django.middleware.csrf.CsrfViewMiddleware',
     7      'django.contrib.auth.middleware.AuthenticationMiddleware',
     8      'django.contrib.messages.middleware.MessageMiddleware',
     9      'django.middleware.clickjacking.XFrameOptionsMiddleware',
    10   
    11  ]

    好了,这样,每次来一个访问的都可以增加一次记录

  • 相关阅读:
    jmeter实战
    安卓学习进度_11
    安卓学习进度_10
    安卓学习进度_9
    安卓学习进度_8
    安卓软件学习进度_7
    安卓学习进度_6
    安卓软件学习进度_5
    安卓软件学习进度_4
    安卓软件学习进度_3
  • 原文地址:https://www.cnblogs.com/zuoshoushizi/p/7849987.html
Copyright © 2011-2022 走看看