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  ]

 

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

posted @ 2017-11-17 09:33  左手十字  阅读(225)  评论(0编辑  收藏  举报