django middleware笔记
1.自定义的middleware写好后,要注册在setting中。系统也自带若干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', 'demo.auth.AuthMiddleware', #拦截器,子系统携带token去SSO server(SSO_URL),通过token查询user信息, # 并把user放入request.session, # 查不到user则token为假的,验证错误 ]
2. 看实例,定义在demo.auth.py 文件中的AuthMiddleware class ,在setting.py中已经注册
要求:
(1)中间件类须继承自 django.utils.deprecation.MiddlewareMixin中间件类须实现下列五个方法中的一个或多个:
def process_request(self, request): 执行视图之前被调用,在每个请求上调用回None或HttpResponse对象
def process_view(self, request, callback, callback_args,callback_kwargs): 调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
def process_response(self, request, response): 所有响应返回浏览器之前被用,在每个请求上调用,返回HttpResponse对象
def process_exception(self, request, exception): 当处理过程中抛出异常时用,返回一个HttpResponse对象
def process_template_response(self, request, response): 在视图刚好执行之后被调用,在每个请求上调用,返回实现了render方法的响应对象
注: 中间件中的大多数方法在返回None时表示忽略当前操作进入下一项事件,
当返HttpResponese对象时表示此请求结果,直接返回给客户端。
典型应用场景:
可以使用中间键来增加验证码
在爬虫scrapy框架中可以使用中间键来增加User-Agent 或者随机生成代理。
参考了博客:https://blog.csdn.net/zsx2541577860/article/details/95041082