- 此中间件对后台网址访问做了是否登录的判断
- 关于网站后台要求:只要访问的URL地址是以 "/admin" 开头的都会执行是否登录判断验证。
(1). 在myadmin应用中创建中间件
- 创建文件:
myobject/myadmin/shopmiddleware.py, 代码如下:
from django.shortcuts import redirect
from django.urls import reverse
class ShopMiddleware(object):
def __init__(self, get_response):
self.get_response = get_response
def __call__(self, request):
urllist = ['/myadmin/login','/myadmin/dologin','/myadmin/logout','/myadmin/verify']
if re.match(r"^/myadmin",path) and (path not in urllist):
if "adminuser" not in request.session:
return redirect(reverse('myadmin_login'))
response = self.get_response(request)
(2). 将自定义的中间件注册到项目中
- 编辑
myobject/settings.py 配置文件, 添加如下代码
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'myadmin.shopmiddleware.ShopMiddleware', #注册中间件
(3). 配置路由、模板并测试中间件
- 3.1 配置路由
myobject/myadmin/urls.py 加入如下代码
path('login', index.login, name="myadmin_login"),
path('dologin', index.dologin, name="myadmin_dologin"),
path('logout', index.logout, name="myadmin_logout"),
#path('verify', index.verify, name="myadmin_verify"), #验证码
- 3.2 编写视图
myobject/myadmin/views/index.py文件 并加入如下代码:
# ==============后台管理员操作====================
return render(request,'myadmin/index/login.html')
- 3.3 创建登录模板文件:
templates/myadmin/index/login.html 代码如下:
{% load static from staticfiles %}
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" name="viewport">
<link rel="stylesheet" href="{% static 'myadmin/bower_components/bootstrap/dist/css/bootstrap.min.css' %}">
<link rel="stylesheet" href="{% static 'myadmin/bower_components/font-awesome/css/font-awesome.min.css' %}">
<link rel="stylesheet" href="{% static 'myadmin/bower_components/Ionicons/css/ionicons.min.css' %}">
<link rel="stylesheet" href="{% static 'myadmin/dist/css/AdminLTE.min.css' %}">
<!-- AdminLTE 皮肤.这里选择的是skin-blue样式,我们还可以有其他皮肤可以选择. -->
<link rel="stylesheet" href="{% static 'myadmin/dist/css/skins/skin-blue.min.css' %}">
<script src="{% static 'myadmin/local/js/html5shiv.min.js' %}"></script>
<script src="{% static 'myadmin/local/js/respond.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'myadmin/local/css/google_fonts.css' %}">
<body class="hold-transition login-page">
<a href="index2.html"><b>餐饮系统后台管理</b></a>
<div class="login-box-body">
<p class="login-box-msg" style="color:red">登录账号或密码错误!</p>
<form action="index2.html" method="post">
<div class="form-group has-feedback">
<input type="text" class="form-control" placeholder="账号">
<span class="glyphicon glyphicon-user form-control-feedback"></span>
<div class="form-group has-feedback">
<input type="password" class="form-control" placeholder="密码">
<span class="glyphicon glyphicon-lock form-control-feedback"></span>
<div class="form-group has-feedback">
<input type="text" class="form-control" style="width:150px" placeholder="验证码">
<span class="form-control-feedback" style="width:150px">
<img src="{% static 'myadmin/dist/img/verify.png' %}"/>
<button type="submit" class="btn btn-primary btn-block btn-flat">登录</button>
<!-- /.login-box-body -->
<script src="{% static 'myadmin/bower_components/jquery/dist/jquery.min.js' %}"></script>
<script src="{% static 'myadmin/bower_components/bootstrap/dist/js/bootstrap.min.js' %}"></script>
(4). 启动服务测试,网站后台就进不去了,统一调跳转登录页面中