Django 用戶認(rèn)證Auth組件的使用
Django 用戶認(rèn)證(Auth)組件
Django 用戶認(rèn)證(Auth)組件一般用在用戶的登錄注冊上,用于判斷當(dāng)前的用戶是否合法,并跳轉(zhuǎn)到登陸成功或失敗頁面。
Django 用戶認(rèn)證(Auth)組件需要導(dǎo)入 auth 模塊:
# 認(rèn)證模塊from django.contrib import auth# 對(duì)應(yīng)數(shù)據(jù)庫from django.contrib.auth.models import User
返回值是用戶對(duì)象。
創(chuàng)建用戶對(duì)象的三種方法:
create():創(chuàng)建一個(gè)普通用戶,密碼是明文的。 create_user():創(chuàng)建一個(gè)普通用戶,密碼是密文的。 create_superuser():創(chuàng)建一個(gè)超級(jí)用戶,密碼是密文的,要多傳一個(gè)郵箱 email 參數(shù)。參數(shù):
username: 用戶名。
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)證用戶的用戶名和密碼使用 authenticate() 方法,從需要 auth_user 表中過濾出用戶對(duì)象。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
username:用戶名 password:密碼**返回值:**如果驗(yàn)證成功,就返回用戶對(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)證成功的用戶加 session,將 request.user 賦值為用戶對(duì)象。
登陸使用 login() 方法。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
request:用戶對(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/')
注銷用戶使用 logout() 方法,需要清空 session 信息,將 request.user 賦值為匿名用戶。
使用前要導(dǎo)入:
from django.contrib import auth
參數(shù):
request:用戶對(duì)象
返回值:None
實(shí)例
def logout(request):ppp = auth.logout(request)print(ppp) # Nonereturn redirect('/login/')
設(shè)置裝飾器,給需要登錄成功后才能訪問的頁面統(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頁面。。。')
設(shè)置從哪個(gè)頁面訪問,登錄成功后就返回哪個(gè)頁面。
strong>解析:
django 在用戶訪問頁面時(shí),如果用戶是未登錄的狀態(tài),就給用戶返回登錄頁面。
此時(shí),該登錄頁面的 URL 后面有參數(shù):next=用戶訪問的頁面的 URL。
因此,設(shè)置在用戶登錄成功后重定向的 URL 為 next 參數(shù)的值。
但是,若用戶一開始就輸入登錄頁面 logi,request.GET.get(“next”) 就取不到值,所以在后面加 or,可以設(shè)置自定義返回的頁面。
實(shí)例
# 如果直接輸入 login、get() 就取不到值,path 可以自定義設(shè)置返回的頁面path = request.GET.get('next') **or** '/index/'**return** redirect(path)
到此這篇關(guān)于Django 用戶認(rèn)證Auth組件的使用的文章就介紹到這了,更多相關(guān)Django 用戶認(rèn)證Auth組件內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 得到XML文檔大小的方法2. JSP+Servlet實(shí)現(xiàn)文件上傳到服務(wù)器功能3. XML入門的常見問題(二)4. 在JSP中使用formatNumber控制要顯示的小數(shù)位數(shù)方法5. 如何在jsp界面中插入圖片6. ASP常用日期格式化函數(shù) FormatDate()7. jsp實(shí)現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法8. chat.asp聊天程序的編寫方法9. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)10. Jsp中request的3個(gè)基礎(chǔ)實(shí)踐
