本文主要是介绍2021-08-03-DJ-022 django中自定义中间件的介绍和实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这一篇研究中间件middleware
源代码
视频待审核后就可以看了
1.中间件介绍
中间件主要是为方法在被调用的前后,做一些事,类似于python中的装饰器函数,调用包装函数前和调用包装函数后做什么事情。
中间件主要可以实现:权限验证、限制IP、限制请求次数、跨域请求、访问日志、统计汇总错误信息等功能
自定义一个中间件的流程为:
1.建立中间件包和文件
2.继承自MiddlewareMixin类
3.在settings的中间件处注册
中间件有5个函数,前三个为常用
1.process_request(),表示从django框架到urls路由的过程中
2.process_response(),表示从视图函数向django框架响应数据的过程中
3.process_view(),表示从urls路由到视图函数的过程中
4.process_template_response(),表示在视图中渲染模板的过程中
5.process_exception(),表示请求到响应的整个过程出现异常的处理
2.自定义登录检查中间件login_checkMiddleware类
这里在中间件的情况下实现下前面检查用户是否登录的那个返回到登录页面的功能
新建一个mymiddleware包
里面建一个login_check.py模块
模块中建一个login_checkMiddleware类
在settings中间件列表注册
'mymiddleware.login_check.LoginCheckMiddleware',
login_check.py
里面设计了三个函数,另外两个给大家展示的是参数类型
因为对于所有请求都会经过这个中间件,所以请求环节的函数设计上设置了一个排除列表,因为不可能自己的登录 页面也要重定向吧,所以就排除了,登录页面的验证码也要排除。
from django.http import HttpResponse, HttpResponseRedirect
from django.utils.deprecation import MiddlewareMixinclass LoginCheckMiddleware(MiddlewareMixin):def process_request(self,request):print('login_checkMiddleware,request',request.path,request.META['REMOTE_ADDR'])excludelist=['/main/login','/main/imgcode']if request.path not in excludelist:#验证 用户是否已经登录if not request.COOKIES.get('token'):return HttpResponseRedirect('/main/login')def process_view(self, request, callback, callback_args, callback_kwargs):print('login_checkMiddleware,view')def process_response(self,request,response):print('login_checkMiddleware,response')return response
效果直接看视频,没有再跳三秒回到主页了 ,已经通过中间件从源头控制了
这篇关于2021-08-03-DJ-022 django中自定义中间件的介绍和实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!