[英]login sessions for django
我正在嘗試在我的網絡應用程序中設置登錄會話但無法使其工作。 我是django的新手並閱讀會話文檔,但沒有連接到我的網絡應用程序。 我現在想要的只是檢查用戶是否已登錄,如果沒有重定向到登錄頁面。
下面是我試圖合並登錄會話的代碼。
settings.py
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'logins',
'dashboards'
)
MIDDLEWARE_CLASSES = (
'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',
)
urls.py
from django.conf.urls import patterns, include, url
from django.conf import settings
from django.conf.urls.static import static
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
url(r'^$', 'logins.views.login', name='login'),
url(r'^accounts/auth/$', 'logins.views.auth_view', name='auth_view'),
url(r'^accounts/dashboard/$', 'dashboards.views.dashboard', name='dashboard'),
url(r'^accounts/logout/$', 'logins.views.logout', name='logout'),
url(r'^accounts/invalid/$', 'logins.views.invalid', name='invalid'),
views.py用於登錄
from django.shortcuts import render, render_to_response, RequestContext
from django.http import HttpResponseRedirect, HttpResponse
from django.contrib import auth
from django.core.context_processors import csrf
def login(request):
c = {}
c.update(csrf(request))
return render_to_response('login.html', c)
def auth_view(request):
username = request.POST.get('username', '')
password = request.POST.get('password', '')
user = auth.authenticate(username=username, password=password)
if user is not None and user.is_active:
auth.login(request, user)
return HttpResponseRedirect('/accounts/dashboard')
else:
return HttpResponseRedirect('/accounts/invalid')
def logout(request):
auth.logout(request)
return render_to_response('logout.html')
def invalid(request):
return render_to_response('invalid.html')
views.py用於登錄的儀表板應用程序
from django.shortcuts import render, render_to_response, RequestContext
from django.http import HttpResponseRedirect, HttpResponse
from django.contrib import auth
from django.core.context_processors import csrf
def dashboard(request):
return render_to_response('dashboard.html')
在django中執行此操作非常簡單:在此示例中,會話將保存在db中(您必須將django應用程序與數據庫同步)
用戶登錄:
from django.contrib.auth.models import User
from django.contrib.auth import authenticate, login
if request.method == 'POST':
username = request.POST.get('nickname','')
password = request.POST.get('password','')
user = authenticate(username=username, password=password)
if user is not None:
if user.is_active:
request.session.set_expiry(86400) #sets the exp. value of the session
login(request, user) #the user is now logged in
對於其他網站(您需要登錄的地方):
def my_func(request):
if request.user.is_authenticated():
print (user.id) #the user is loggedin
或者您使用login_require
-decorator:
from django.contrib.auth.decorators import login_required
@login_required
def my_func(request):
print(user.id) #the user is loggedin
您可以使用Django的內置身份驗證系統來檢查用戶是否已登錄。 您可以使用login_required裝飾器。
views.py
from django.contrib.auth.decorators import login_required
@login_required
def my_view_login_required(request):
return render_to_response('dashboard.html')
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.