前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django 用户登陆访问限制 @login_required

Django 用户登陆访问限制 @login_required

作者头像
菲宇
发布2019-06-13 11:37:31
1.4K0
发布2019-06-13 11:37:31
举报
文章被收录于专栏:菲宇菲宇

在网站开发过程中,经常会遇到这样的需求:用户登陆系统才可以访问某些页面,如果用户没有登陆而直接访问就会跳转到登陆界面。

要实现这样的需求其实很简单: 1、在相应的 view 方法的前面添加 django 自带的装饰器 @login_required 2、在 settings.py 中配置 LOGIN_URL 参数 3、修改 login.html 表单中的 action 参数

代码语言:javascript
复制
# views.py

from djanco.contrib.auth.decorators import login_required

from django.shortcuts import render_to_response

@login_required

def index(request):

return render_to_response('index.html')
代码语言:javascript
复制
# settings.py

....

LOGIN_URL = '/accounts/login/' # 根据你网站的实际登陆地址来设置

....

如果要使用 django 默认登陆地址,则可以通过在 urls.py 中添加如此配置:

代码语言:javascript
复制
# urls.py

....

url(r'^accounts/login/', views.login),

....
代码语言:javascript
复制
# login.html

<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 -->
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年04月09日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档