1. 概念
中间件是一个钩子框架,咱们可以理解他是个过滤器,它们可以过滤发送到Django视图层的请求,也可以过滤视图层发送给前端的响应.
它是一个轻量级的底层插件系统,用途在全局修改Django的输入或者输出
每个中间件负责特定的功能,例如,Django 包含的一个中间件组件AuthenticationMiddleware ,它使用会话将用户和请求关联起来。
2.中间件的使用
- process_request(self,request) 此方法用于在请求到来时处理请求
- peocess_view(self,request,fnc,arg,kwarg)在本次将要执行的view函数被调用前处理请求
- process_response(self,request,response)在执行完view函数准备发送响应到客户端之前执行
- process_exception(self,request,exception)View函数在抛出异常的时候该函数被调用,得到的exception参数是实际上跑出的异常实例.通过此方法可以进行很好的错误控制,提供有好的用户界面
5.process_template_response 在视图view刚好执行完毕之后调用
from:http://python.usyiyi.cn/documents/django_182/topics/http/middleware.html
3.动手编写自己的中间件
1.在project/app/下建立文件夹,名字叫middleware
2.在middleware文件夹里面新建User_Based_Exception_Middleware.py文件
3.编辑User_Based_Exception_Middleware.py文件
import sys
from django.conf import settings
from django.http import HttpResponse
class UserBasedExceptionMiddleware(object):
def process_request(self, request):
if request.user.is_superuser:
return HttpResponse("lalalalalalallllllllllllllllll")
4.在settings.py 的MIDDLEWARE_CLASSES将新建立的中间件路径加上去
MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.security.SecurityMiddleware',
#新加的中间件路径
'devnav.middleware.User_Based_Exception_Middleware.UserBasedExceptionMiddleware'
)