文章预览
前言
中间件是一个钩子框架,它们可以介入Django 的请求和响应处理过程。 它是一个轻量级、底层的“插件”系统,用于在全局修改Django 的输入或输出。每个中间件组件负责完成某个特定的功能。
创建一个新django项目时,默认自带的中间件有:(在settings.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',
]
二、基于类的中间件详解
2.1、 process_request
process_request(self,request)
在请求传达到路由系统之前处理从服务器wsgi传来的请求。
它的返回值可以是None
也可以是HttpResponse
对象。
返回值是None
的话,按正常流程继续走,交给下一个中间件处理或路由系统处理;如果是HttpResponse
对象,Django将不执行视图函数,而该HttpResponse对象会经过本层process_response
返回给浏览器
2.2、 process_view
process_view(self, request, view_func, view_args, view_kwargs)
会在Django 调用视图之前被调用;
它应该返回一个None
或一个HttpResponse
对象。
如果返回None
,Django
将会继续处理这个请求,执行其它的process_view()
中间件,然后调用对应的视图。 如果它返回一个HttpResponse对象,Django
不会调用相应的视图;HttpResponse
会经由本层及本层外层的响应中间件返回给浏览器
2.3.、process_exception
process_exception(self, request, exception)
当一个视图抛出异常时,Django会调用process_exception()
来处理。
process_exception()
应该返回一个 None
或者一个HttpResponse对象。 如果它返回一个HttpResponse
对象,则将应用模板响应和响应中间件,并将生成的响应返回给浏览器。 否则,默认的异常处理开始工作。
2.4、 process_template_response
process_template_response(self,request,response)
如果响应的实例有render()
方法,process_template_response()
在视图刚好执行完毕之后被调用。
这个方法必须返回一个实现了render
方法的响应对象。
2.5、 process_response
process_response(self, request, response)
处理响应:处理本层或本层内层传递来的响应
三、使用方法
from django.utils.deprecation import MiddlewareMixin
# from django.http import HttpResponse
from django.shortcuts import HttpResponse, redirect
# 方式一:
class MyMiddleware(MiddlewareMixin):
def process_request(self, request):
next_url = request.path_info
if not request.path_info.startswith("/login/"):
# 做登录验证
login_flag = request.session.get("login", "")
if not login_flag:
return redirect("/login/?next={}".format(next_url))
def process_view(self, request, view_func, view_args, view_kwargs):
pass
def process_exception(self, request, exception):
if isinstance(exception, ValueError):
return HttpResponse("404")
def process_response(self, request, response):
return response
# 方式二:
class SimpleMiddleware(object):
def __init__(self, get_response):
self.get_response = get_response
# 一次性配置和初始化。
def __call__(self, request):
# Code to be executed for each request before
# the view (and later middleware) are called.
# 这里写的代码会在视图被调用前执行来处理请求
response = self.get_response(request)
# 这里写的代码会在视图调用后执行来处理响应
# Code to be executed for each request/response after
# the view is called.
return response
def process_view(self, request, view_func, view_args, view_kwargs):
pass
def process_exception(self, request, exception):
pass
def process_template_response(self, request, response):
pass
然后在settings.py
中进行配置
# 在settings.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',
'mymiddlewares.middlewares.MyMiddleware',
'mymiddlewares.middlewares.SimpleMiddleware',
]