Django 用戶(hù)認(rèn)證Auth組件的使用
Django 用戶(hù)認(rèn)證(Auth)組件
Django 用戶(hù)認(rèn)證(Auth)組件一般用在用戶(hù)的登錄注冊(cè)上,用于判斷當(dāng)前的用戶(hù)是否合法,并跳轉(zhuǎn)到登陸成功或失敗頁(yè)面。
Django 用戶(hù)認(rèn)證(Auth)組件需要導(dǎo)入 auth 模塊:
# 認(rèn)證模塊from django.contrib import auth# 對(duì)應(yīng)數(shù)據(jù)庫(kù)from django.contrib.auth.models import User
返回值是用戶(hù)對(duì)象。
創(chuàng)建用戶(hù)對(duì)象的三種方法:
create():創(chuàng)建一個(gè)普通用戶(hù),密碼是明文的。 create_user():創(chuàng)建一個(gè)普通用戶(hù),密碼是密文的。 create_superuser():創(chuàng)建一個(gè)超級(jí)用戶(hù),密碼是密文的,要多傳一個(gè)郵箱 email 參數(shù)。參數(shù):
username: 用戶(hù)名。
password:密碼。
email:郵箱 (create_superuser 方法要多加一個(gè) 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=’runboo@163.com’)

驗(yàn)證用戶(hù)的用戶(hù)名和密碼使用 authenticate() 方法,從需要 auth_user 表中過(guò)濾出用戶(hù)對(duì)象。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
username:用戶(hù)名 password:密碼**返回值:**如果驗(yàn)證成功,就返回用戶(hù)對(duì)象,反之,返回 None。
實(shí)例
**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)

給驗(yàn)證成功的用戶(hù)加 session,將 request.user 賦值為用戶(hù)對(duì)象。
登陸使用 login() 方法。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
request:用戶(hù)對(duì)象
返回值:None
實(shí)例
**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/')

注銷(xiāo)用戶(hù)使用 logout() 方法,需要清空 session 信息,將 request.user 賦值為匿名用戶(hù)。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
request:用戶(hù)對(duì)象
返回值:None
實(shí)例
def logout(request):ppp = auth.logout(request)print(ppp) # Nonereturn redirect('/login/')
設(shè)置裝飾器,給需要登錄成功后才能訪問(wèn)的頁(yè)面統(tǒng)一加裝飾器。
使用前要導(dǎo)入:
from django.contrib.auth.decorators import login_required
實(shí)例
**from** django.contrib.auth.decorators **import** login_required @login_required**def** index(request): **return** HttpResponse('index頁(yè)面。。。')
設(shè)置從哪個(gè)頁(yè)面訪問(wèn),登錄成功后就返回哪個(gè)頁(yè)面。
strong>解析:
django 在用戶(hù)訪問(wèn)頁(yè)面時(shí),如果用戶(hù)是未登錄的狀態(tài),就給用戶(hù)返回登錄頁(yè)面。
此時(shí),該登錄頁(yè)面的 URL 后面有參數(shù):next=用戶(hù)訪問(wèn)的頁(yè)面的 URL。
因此,設(shè)置在用戶(hù)登錄成功后重定向的 URL 為 next 參數(shù)的值。
但是,若用戶(hù)一開(kāi)始就輸入登錄頁(yè)面 logi,request.GET.get(“next”) 就取不到值,所以在后面加 or,可以設(shè)置自定義返回的頁(yè)面。
實(shí)例
# 如果直接輸入 login、get() 就取不到值,path 可以自定義設(shè)置返回的頁(yè)面path = request.GET.get('next') **or** '/index/'**return** redirect(path)

到此這篇關(guān)于Django 用戶(hù)認(rèn)證Auth組件的使用的文章就介紹到這了,更多相關(guān)Django 用戶(hù)認(rèn)證Auth組件內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python中文本字符處理的簡(jiǎn)單方法記錄2. 使用Blazor框架實(shí)現(xiàn)在前端瀏覽器中導(dǎo)入和導(dǎo)出Excel3. 如何從Python的cmd中獲得.py文件參數(shù)4. ASP基礎(chǔ)知識(shí)Command對(duì)象講解5. vscode運(yùn)行php報(bào)錯(cuò)php?not?found解決辦法6. Python-openpyxl表格讀取寫(xiě)入的案例詳解7. Python使用Selenium自動(dòng)進(jìn)行百度搜索的實(shí)現(xiàn)8. JavaScript實(shí)現(xiàn)留言板實(shí)戰(zhàn)案例9. PHP laravel實(shí)現(xiàn)導(dǎo)出PDF功能10. JS中6個(gè)對(duì)象數(shù)組去重的方法

網(wǎng)公網(wǎng)安備