员工管理系统的项目中,我们需要先检查用户是否登录,如果已经登录,才能展示用户列表、部门列表等内容,如果未登录,则需要跳转到登录页面,让用户先登录。
所以,我们要在18个视图函数前面统一加入用户是否登录的判断,代码如下:
info = request.session.get('info')
if info is None:
return redirect('/login/')
这个判断可以借助Django的中间件,会非常非常省事儿
中间件工作原理:
如上图所示,浏览器的请求进入Django要先经过Django的中间件(process_request),如果请求中途无法通过某一个中间件,则不会走到下一个中间件,而是直接原路返回(process_response)。
如何使用创建和编写Django中间件:
步骤1、在app01中创建middleware文件夹
2、在middleware文件夹中创建一个.py文件,比如可以命名为auth.py
3、在auth.py中编写中间件
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse, redirect
class AuthMiddleware(MiddlewareMixin):
"""中间件1"""
# 如果方法中没有返回值(即:返回None),则继续向后走,
# 如果有返回值(HttpResponse, render, redirect等),则不再走后面的中间件,而是直接返回给浏览器
def process_request(self, request):
# 0. 排除那些不需要登录就能访问的页面
# request.path_info 获取当前用户请求的URL
if request.path_info == '/login/':
return
# 1. 读取当前访问用户的session的信息,如果能读到,说明该用户已经登录过了,就可以继续向后走
info_dict = request.session.get("info")
if info_dict:
return
# 2. 如果没有登录过,返回登录页面
else:
return redirect('/login/')
def process_response(self, request, response):
# print("M1.走了")
return response
4、在settings.py中的middleware变量中些上这个新写的中间件