Django中间件实现第三方用户登陆状态检测

由于项目需要使用公司内部统一权限登陆平台,所以不能使用Django内置的认证模块,

使用第三方认证系统,要解决每个URL登陆验证的问题

代码实现:

# ~*~ coding: utf-8 ~*~
from django.http import HttpResponseRedirect


class LoginMiddleware:
    SAFE_URL_PATTERN = ('/singin/','/oauth/authorizatiocallback','/userlogin/')

    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        if request.session.get('jobnumber'):
            response = self.get_response(request)
            return response
        else:
            if request.path in self.SAFE_URL_PATTERN:
                response = self.get_response(request)
                return response
            else:
                return HttpResponseRedirect("/singin/")

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注