1. 程式人生 > 程式設計 >Django 使用者認證Auth元件的使用

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')

img

from django.contrib.auth.models import User 
User.objects.create(username='runbooo',password='123')

img

from django.contrib.auth.models import User 
User.objects.create(username='runboooo',password='123',email='[email protected]')

img

驗證使用者的使用者名稱和密碼使用 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)

img

給驗證成功的使用者加 session,將 request.user 賦值為使用者物件。

登陸使用 login() 方法。

使用前要匯入:

from django.contrib import auth

引數:

request:使用者物件

返回值:None

例項

**def** login(request):
 **if** request.method == "GET":
  **return** render(request,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/")

img

登出使用者使用 logout() 方法,需要清空 session 資訊,將 request.user 賦值為匿名使用者。

使用前要匯入:

from django.contrib import auth

引數:

request:使用者物件

返回值:None

例項

def logout(request):
ppp = auth.logout(request)
print(ppp) # None
return 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)

img

到此這篇關於Django 使用者認證Auth元件的使用的文章就介紹到這了,更多相關Django 使用者認證Auth元件內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!