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 MiddlewareMixin


class 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



效果直接看视频,没有再跳三秒回到主页了 ,已经通过中间件从源头控制了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Amoor123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值