Djangoユーザー登録アクセス制限@login_required
7966 ワード
http://www.jianshu.com/p/d5bd01eb08d2
ウェブサイトの開発過程で、よくこのような需要があります.ユーザーがログインしてこそ、いくつかのページにアクセスできます.ユーザーがログインしていないと、ログイン画面に直接アクセスできます.
このような需要を実現するには簡単です.1、相応のview方法の前にdjangoが持っている装飾器@login_を追加します.required 2、settings.pyにLOGIN_を配置する.URLパラメータ3、login.1フォームのactionパラメータを変更します.
ウェブサイトの開発過程で、よくこのような需要があります.ユーザーがログインしてこそ、いくつかのページにアクセスできます.ユーザーがログインしていないと、ログイン画面に直接アクセスできます.
このような需要を実現するには簡単です.1、相応のview方法の前にdjangoが持っている装飾器@login_を追加します.required 2、settings.pyにLOGIN_を配置する.URLパラメータ3、login.1フォームのactionパラメータを変更します.
# 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')
# settings.py
....
LOGIN_URL = '/accounts/login/' #
....
djangoのデフォルトの登録アドレスを使用するなら、urls.pyにこのような設定を追加することができます.# urls.py
....
url(r'^accounts/login/', views.login),
....
# login.html
<div class="container">
<form class="form-signin" action="/accounts/login/" method="post">
{% csrf_token %}
<h2 class="form-signin-heading" align="center"> h2>
<label for="inputUsername" class="sr-only">usernamelabel>
<input type="text" name="username" id="inputUsername" class="form-control" placeholder="username" required autofocus>
<label for="inputPassword" class="sr-only">Passwordlabel>
<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>