Django中auth模塊用戶認(rèn)證的使用
auth模塊是什么
auth模塊時(shí)django自帶的用戶認(rèn)證模塊
- 開發(fā)一個(gè)網(wǎng)站的時(shí)候,無可避免的需要設(shè)計(jì)實(shí)現(xiàn)網(wǎng)站的用戶系統(tǒng)。此時(shí)我們需要實(shí)現(xiàn)包括用戶注冊、用戶登錄、用戶認(rèn)證、注銷、修改密碼等功能。
- Django它內(nèi)置了強(qiáng)大的用戶認(rèn)證系統(tǒng) - - - auth,它默認(rèn)使用 auth_user 表來存儲(chǔ)用戶數(shù)據(jù)
auth模塊常用方法
authenticate()
提供了用戶認(rèn)證功能,即驗(yàn)證用戶名以及密碼是否正確,一般需要username 、password兩個(gè)關(guān)鍵字參數(shù)。
如果認(rèn)證成功(用戶名和密碼正確有效),便會(huì)返回一個(gè) User 對象。
authenticate()會(huì)在該 User 對象上設(shè)置一個(gè)屬性來標(biāo)識后端已經(jīng)認(rèn)證了該用戶,且該信息在后續(xù)的登錄過程中是需要的。
用法
user = authenticate(username='usernamer', password='password') #用戶名和密碼驗(yàn)證成功返回一個(gè)user對象,
login(HttpRequest, user)
- 該函數(shù)接受一個(gè)HttpRequest對象,以及一個(gè)經(jīng)過認(rèn)證的User對象。
- 該函數(shù)實(shí)現(xiàn)一個(gè)用戶登錄的功能。它本質(zhì)上會(huì)在后端為該用戶生成相關(guān)session數(shù)據(jù)。
用法
from django.contrib.auth import authenticate, login def my_view(request): ?# 定義一個(gè)用于認(rèn)證函數(shù),拿到用戶輸入的用戶名和密碼 ? ? username = request.POST['username'] ? ? password = request.POST['password'] ? ? user = authenticate(username=username, password=password) ?# 拿到用戶名和密碼通過authenticate()拿到用戶對應(yīng), ? ? if user is not None: ?# 當(dāng)拿到的用戶對象存在是說明認(rèn)證成功,返回的是一個(gè)用戶對象,認(rèn)證是吧則返回一個(gè)none ? ? ? ? login(request, user) ?# 將登陸成功的返回的user對象傳入,這樣就可以記錄下用戶的登錄狀態(tài),(在全局存儲(chǔ)用戶信息,在任何視圖函數(shù)都可以取出來),人家有什么參數(shù)就傳什么 ? ? ? ? # Redirect to a success page. ? ? ? ? ... ? ? else: ? ? ? ? # Return an 'invalid login' error message. ? ? ? ? ...
logout(request)
該函數(shù)接受一個(gè)HttpRequest對象,無返回值。
當(dāng)調(diào)用該函數(shù)時(shí),當(dāng)前請求的session信息會(huì)全部清除。該用戶即使沒有登錄,使用該函數(shù)也不會(huì)報(bào)錯(cuò)。
用法
user.set_password(password='') user.save() ?# 修改完成密碼一定要保存 from django.contrib.auth import logout def logout_view(request): ? logout(request) ?# 注銷登錄狀態(tài),本事就是把session信息刪掉 ? # Redirect to a success page.
is_authenticated()
用來判斷當(dāng)前請求是否通過了認(rèn)證。
用法
def my_view(request): if not request.user.is_authenticated(): # 判斷當(dāng)前拿到的用戶對象是否通過認(rèn)證,判斷用戶登沒登陸 return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path)) # 沒有通過用戶認(rèn)證,那么我們就重定向讓用戶跳轉(zhuǎn)到登陸頁面在進(jìn)行重新登陸
login_requierd()
auth 給我們提供的一個(gè)裝飾器工具,用來快捷的給某個(gè)視圖添加登錄校驗(yàn),login_requierd有一個(gè)參數(shù),login_url當(dāng)我們沒有登錄可以讓他跳到我們指定的url。
若用戶沒有登錄,則會(huì)跳轉(zhuǎn)到django默認(rèn)的 登錄URL '/accounts/login/ ’ 并傳遞當(dāng)前訪問url的絕對路徑 (登陸成功后,會(huì)重定向到該路徑)。
如果需要自定義登錄的URL,則需要在settings.py文件中通過LOGIN_URL進(jìn)行修改。
LOGIN_URL = '/login/' # 這里配置成你項(xiàng)目登錄頁面的路由,全局的
用法
from django.contrib.auth.decorators import login_required @login_required # 添加一個(gè)登錄校驗(yàn)的裝飾器,登錄成功才會(huì)走到下面,否則會(huì)跳轉(zhuǎn)到django默認(rèn)的登錄 def my_view(request): ...
create_user()&create_superuser()
auth 提供的一個(gè)創(chuàng)建新用戶的方法,需要提供必要參數(shù)(username、password)等。
用法:
from django.contrib.auth.models import User user = User.objects.create_user(username='用戶名',password='密碼',email='郵箱',...) ?# 創(chuàng)建普通的用戶 user1 = UserInfo.objects.create_superuser(username='alan',password='alan123',email='alan@136.com') ? # 創(chuàng)建超級用戶,我們可以通過超級用戶名和密碼登陸到管理員后臺(tái)
check_password(password)
auth 提供的一個(gè)檢查密碼是否正確的方法,需要提供當(dāng)前請求用戶的密碼。
密碼正確返回True,否則返回False。
用法:
ok = user.check_password('密碼') # 核對密碼是否正確,返回一個(gè)true或false
set_password(password)
auth 提供的一個(gè)修改密碼的方法,接收要設(shè)置的新密碼作為參數(shù)。
用法:
user.set_password(password='') # 重新設(shè)置密碼 user.save() # 密碼修改完成一定要保存,否則新密碼不會(huì)創(chuàng)建成功,數(shù)據(jù)庫中任然是舊密碼的對一個(gè)的加密字符串
應(yīng)用:
@login_required # 設(shè)置密碼前進(jìn)行登錄校驗(yàn) def set_password(request): # 封裝了一個(gè)設(shè)置密碼的函數(shù) user = request.user # 拿到用戶 err_msg = '' if request.method == 'POST': old_password = request.POST.get('old_password', '') # 拿到舊密碼 new_password = request.POST.get('new_password', '') # 拿到新密碼 repeat_password = request.POST.get('repeat_password', '') # 檢查舊密碼是否正確 if user.check_password(old_password): # 核對舊密碼是否正確,正確再判斷新密碼是否為空,兩次新密碼設(shè)置是否一致 if not new_password: err_msg = '新密碼不能為空' elif new_password != repeat_password: err_msg = '兩次密碼不一致' else: user.set_password(new_password) # 這是新密碼 user.save() # 設(shè)置完新密碼一定要保存 return redirect("/login/") # 保存完成后重新定向到登陸頁面,在輸入新密碼進(jìn)行登錄,登錄成功則說明新密碼設(shè)置成功 else: err_msg = '原密碼輸入錯(cuò)誤' content = { 'err_msg': err_msg, } # return render(request, 'set_password.html', content) # 如果原密碼輸入失敗,則將失敗的信息渲染到前端頁面告訴用戶原密碼輸入錯(cuò)誤
User對象的屬性
- User對象屬性:username, password
- is_staff : 用戶是否擁有網(wǎng)站的管理權(quán)限.
- is_active : 是否允許用戶登錄, 設(shè)置為 False,可以在不刪除用戶的前提下禁止用戶登錄。
擴(kuò)展默認(rèn)的auth_user表
通過繼承內(nèi)置的AbstractUser類,來定義一個(gè)自己的Model類。從而實(shí)現(xiàn)新建另外一張表與內(nèi)置的auth_user表一對一進(jìn)行關(guān)聯(lián)
from django.contrib.auth.models import AbstractUser class UserInfo(AbstractUser): ?# 繼承AbstractUser ? ? """ ? ? 用戶信息表 ? ? """ ? ? nid = models.AutoField(primary_key=True) ?# 這樣就相當(dāng)于在自己的類中可以派生出新的字段 ? ? phone = models.CharField(max_length=11, null=True, unique=True) ? ? def __str__(self): ? ? ? ? return self.username ?# 字符串原樣輸出
按上面的方式擴(kuò)展了內(nèi)置的auth_user表之后,一定要在settings.py中告訴Django,我現(xiàn)在使用我新定義的UserInfo表來做用戶認(rèn)證。
# 引用Django自帶的User表,繼承使用時(shí)需要設(shè)置,不加數(shù)據(jù)庫遷移不了 AUTH_USER_MODEL = "app名.UserInfo"
到此這篇關(guān)于Django中auth模塊用戶認(rèn)證的使用的文章就介紹到這了,更多相關(guān)Django auth模塊用戶認(rèn)證內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用Python刪除本地目錄下某一時(shí)間點(diǎn)之前創(chuàng)建的所有文件的實(shí)例
下面小編就為大家分享一篇用Python刪除本地目錄下某一時(shí)間點(diǎn)之前創(chuàng)建的所有文件的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12Python OpenCV 圖像平移的實(shí)現(xiàn)示例
本篇博客學(xué)習(xí)OpenCV 中關(guān)于圖像平移的方法,核心學(xué)習(xí)到的方法是warpAffine,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06python的time模塊和datetime模塊實(shí)例解析
這篇文章主要介紹了python的time模塊和datetime模塊實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11PyQt5創(chuàng)建一個(gè)新窗口的實(shí)例
今天小編就為大家分享一篇PyQt5創(chuàng)建一個(gè)新窗口的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06python進(jìn)階_淺談面向?qū)ο筮M(jìn)階
下面小編就為大家?guī)硪黄猵ython進(jìn)階_淺談面向?qū)ο筮M(jìn)階。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08