django – 中间件(拦截)
1.项目下新建一个utils目录,在该目录下新建__init__.py
文件、
UserAuthMiddlewre.py文件
2.UserAuthMiddleware.py文件中书写代码如下:
from django.http import HttpResponseRedirect
from django.utils.deprecation import MiddlewareMixin
# 实现定义的有一个uauth(app) models.py 表格Users
from uauth.models import Users
class AuthMiddleware(MiddlewareMixin):
def process_request(self, request):
# 如果为下面的两个请求不做任何处理 return可以终止函数
if request.path == '/uauth/login/' or
request.path == '/uauth/regist/':
return None
# 从cookies中找ticket
ticket = request.COOKIES.get('ticket')
# 判断cookies中有没有ticket
if not ticket:
return HttpResponseRedirect('/uauth/login/')
# 取出表格Users中 ticket 所在列的内容
users = Users.ojects.filter(u_ticket=ticket)
# 判断取出的内容是否有效
if not users:
return HttpResponseRedirect('/uauth/login/')
# 把用户信息存到request.user中
request.user = users[0]
3.在项目下settings.py文件中添加创建的中间件:
MIDDLEWARE=[
'utils.UserAuthMiddleware.AuthMiddleware'
]
4.此时便可以实现拦截了当你访问时, 就会实现跳转到上面指定的路径 /uauth/login/