Django 用戶認證Auth組件的使用
Django 用戶認證(Auth)組件
Django 用戶認證(Auth)組件一般用在用戶的登錄注冊上,用于判斷當前的用戶是否合法,并跳轉到登陸成功或失敗頁面。
Django 用戶認證(Auth)組件需要導入 auth 模塊:
# 認證模塊from django.contrib import auth# 對應數據庫from django.contrib.auth.models import User
返回值是用戶對象。
創建用戶對象的三種方法:
create():創建一個普通用戶,密碼是明文的。 create_user():創建一個普通用戶,密碼是密文的。 create_superuser():創建一個超級用戶,密碼是密文的,要多傳一個郵箱 email 參數。參數:
username: 用戶名。
password:密碼。
email:郵箱 (create_superuser 方法要多加一個 email)。
from django.contrib.auth.models import User User.objects.create(username=’runboo’,password=’123’)
from django.contrib.auth.models import User User.objects.create(username=’runbooo’,password=’123’)
from django.contrib.auth.models import User User.objects.create(username=’runboooo’,password=’123’,email=’[email protected]’)
驗證用戶的用戶名和密碼使用 authenticate() 方法,從需要 auth_user 表中過濾出用戶對象。
使用前要導入:
from django.contrib import auth
參數:
username:用戶名 password:密碼**返回值:**如果驗證成功,就返回用戶對象,反之,返回 None。
實例
**def** login(request): **if** request.method == 'GET': **return** render(request, 'login.html') username = request.POST.get('username') password = request.POST.get('pwd') valid_num = request.POST.get('valid_num') keep_str = request.session.get('keep_str') **if** keep_str.upper() == valid_num.upper(): user_obj = auth.authenticate(username=username, password=password) **print**(user_obj.username)
給驗證成功的用戶加 session,將 request.user 賦值為用戶對象。
登陸使用 login() 方法。
使用前要導入:
from django.contrib import auth
參數:
request:用戶對象
返回值:None
實例
**def** login(request): **if** request.method == 'GET': **return** render(request, 'login.html') username = request.POST.get('username') password = request.POST.get('pwd') valid_num = request.POST.get('valid_num') keep_str = request.session.get('keep_str') **if** keep_str.upper() == valid_num.upper(): user_obj = auth.authenticate(username=username, password=password) **print**(user_obj.username) **if** **not** user_obj: **return** redirect('/login/') **else**: auth.login(request, user_obj) path = request.GET.get('next') **or** '/index/' **print**(path) **return** redirect(path) **else**: **return** redirect('/login/')
注銷用戶使用 logout() 方法,需要清空 session 信息,將 request.user 賦值為匿名用戶。
使用前要導入:
from django.contrib import auth
參數:
request:用戶對象
返回值:None
實例
def logout(request):ppp = auth.logout(request)print(ppp) # Nonereturn redirect('/login/')
設置裝飾器,給需要登錄成功后才能訪問的頁面統一加裝飾器。
使用前要導入:
from django.contrib.auth.decorators import login_required
實例
**from** django.contrib.auth.decorators **import** login_required @login_required**def** index(request): **return** HttpResponse('index頁面。。。')
設置從哪個頁面訪問,登錄成功后就返回哪個頁面。
strong>解析:
django 在用戶訪問頁面時,如果用戶是未登錄的狀態,就給用戶返回登錄頁面。
此時,該登錄頁面的 URL 后面有參數:next=用戶訪問的頁面的 URL。
因此,設置在用戶登錄成功后重定向的 URL 為 next 參數的值。
但是,若用戶一開始就輸入登錄頁面 logi,request.GET.get(“next”) 就取不到值,所以在后面加 or,可以設置自定義返回的頁面。
實例
# 如果直接輸入 login、get() 就取不到值,path 可以自定義設置返回的頁面path = request.GET.get('next') **or** '/index/'**return** redirect(path)
到此這篇關于Django 用戶認證Auth組件的使用的文章就介紹到這了,更多相關Django 用戶認證Auth組件內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
