我们在网站开发过程中,经常会遇到这样的需求:用户登陆系统才可以访问某些页面
如果用户没有登陆而直接访问就会跳转到登陆界面,而不能访问其他页面。
用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址
要实现这样的需求其实很简单:
1、使用django自带的装饰器 @login_required。
2、在相应的view方法的前面添加@login_required
3、并在settings.py中配置LOGIN_URL参数
4、修改login.htlm中的表单action参数
#views.py
1 2 3 4 5 6 7 | from djanco.contrib.auth.decorators import login_required from django.shortcuts import render_to_response from django.http import HttpResponse @login_required def myview(request): return render_to_response('index.html') |
#settings.py
1 2 3 | .... LOGIN_URL = '/accounts/login/' #这个路径需要根据你网站的实际登陆地址来设置 .... |
如果要使用django的默认登陆界面,则可以通过在urls.py中如此配置
#urls.py
1 2 3 4 5 6 7 8 9 10 11 12 | from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^, views.index), url(r'^accounts/login/, views.acc_login), url(r'^logout/, views.acc_logout), url(r'^host/, views.host, name='host'), url(r'^asset/, views.asset,name='asset'), url(r'^audit/, views.audit,name='audit'), ] |
#login.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | <div class="container"> <form class="form-signin" action="/accounts/login/" method="post">{% csrf_token %} <!--csrf_token:生成令牌--> <h2 class="form-signin-heading" align="center">登录系统</h2> <label for="inputUsername" class="sr-only">username</label> <input type="text" name="username" id="inputUsername" class="form-control" placeholder="username" required autofocus> <label for="inputPassword" class="sr-only">Password</label> <input type="password" name="password" id="inputPassword" class="form-control" placeholder="Password" required> <div class="checkbox"> <label> <input type="checkbox" value="remember-me"> 记住密码 </label> </div> <br /> <button class="btn btn-lg btn-primary btn-block" type="submit">登录</button> <br /> <span style="color: red;">{{ login_err }}</span> </form> </div> <!-- /container --> |
本文出自 “苦咖啡's运维之路” 博客,请务必保留此出处http://alsww.blog.51cto.com/2001924/1732435