由于项目需要使用公司内部统一权限登陆平台,所以不能使用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/")