首頁 > 後端開發 > Python教學 > 詳解Django之auth模組(用戶認證)

詳解Django之auth模組(用戶認證)

不言
發布: 2018-04-17 10:41:35
原創
4016 人瀏覽過

這篇文章主要介紹了詳解Django之auth模組(用戶認證),現在分享給大家,也給大家做個參考。一起過來看看吧

auth模組是登入認證方法的一種封裝,之前我們取得使用者輸入的使用者名稱及密碼後需要自己從user表裡查詢有沒有用戶名和密碼符合的對象,

而有了auth模組之後就可以很輕鬆的去驗證用戶的登入資訊是否存在於資料庫中。

除此之外,auth也對session做了一些封裝,方便我們校驗使用者是否已登入

auth裡的方法

#如果想使用auth模組的方法,必須先導入auth模組

from django.contrib import auth
登入後複製

django.contrib.auth中提供了許多方法,這裡主要介紹其中的四個:

1 、authenticate()  

提供了使用者認證,即驗證使用者名稱以及密碼是否正確,一般需要username  password兩個關鍵字參數

如果認證資訊有效,會回傳一個  User  物件。 authenticate()會在User 物件上設定一個屬性標識那種認證後端認證了該用戶,且該資訊在後面的登入過程中是需要的。當我們試著登陸一個從資料庫直接取出來不經過authenticate()的User物件會報錯的! !

user = authenticate(username='someone',password='somepassword')
登入後複製

2 、login(HttpRequest, user)

該函數接受一個HttpRequest對象,以及一個認證了的User物件

此函數使用django的session框架為某個已認證的使用者附加上session id等資訊。

from django.contrib.auth import authenticate, login
  
def my_view(request):
  username = request.POST['username']
  password = request.POST['password']
  user = authenticate(username=username, password=password)
  if user is not None:
    login(request, user)
    # Redirect to a success page.
    ...
  else:
    # Return an 'invalid login' error message.
    ...
登入後複製

3 、logout(request) 登出使用者

此函數接受一個HttpRequest對象,無回傳值。當呼叫函數時,目前請求的session資訊會全部清除。該用戶即使沒有登錄,使用函數也不會報錯。

from django.contrib.auth import logout
  
def logout_view(request):
  logout(request)
 # Redirect to a success page.
登入後複製

4 、user物件的is_authenticated()

要求:

1  使用者登陸後才能存取某些頁面,

2  若使用者沒有登入就造訪該頁面的話直接跳到登入頁面

3  使用者在跳躍的登陸介面中完成登陸後,自動存取跳到之前訪問的位址

方法1:

直接用auth的is_authenticated()方法驗證

def my_view(request):
   if not request.user.is_authenticated():
      return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))
登入後複製

2:

根據request.user.username來驗證,如果為空,則表示沒有登入

def my_view(request):
   if not request.user.username:
      return redirect('%s?next=%s' % (settings.LOGIN_URL, request.path))
登入後複製

方法3:

django已經為我們設計好了一個用於此種情況的裝飾器:login_requierd()

#
from django.contrib.auth.decorators import login_required
   
@login_required
def my_view(request):
 ...
登入後複製

若用戶沒有登錄,則會跳到django預設的登入URL '/accounts/login/ ' (這個值可以在settings檔案中透過LOGIN_URL進行修改)。並傳遞  目前存取url的絕對路徑 ( 登陸成功後,會重定向到該路徑 )。

user物件

User 物件屬性:username,password(必填)password用雜湊演算法儲存到資料庫

is_staff : 使用者是否擁有網站的管理權限.

is_active : 是否允許使用者登入, 設定為``False``,可以不用刪除使用者來禁止使用者登入

# 2.1 、is_authenticated()

如果是真正的User 對象,則傳回值恆為True 。用於檢查使用者是否已經通過了認證。

通過認證並不意味著使用者擁有任何權限,甚至也不檢查該使用者是否處於啟動狀態,這只是表明使用者成功的通過了認證。這個方法很重要, 在後台用request.user.is_authenticated()判斷使用者是否已經登錄,如果true則可以向前台展示request.user.name

##2.2 、建立使用者

使用create_user 輔助函數建立使用者:

from django.contrib.auth.models import User
user = User.objects.create_user(username='',password='',email='')
登入後複製

2.3 、check_password(passwd)

#

user = User.objects.get(username=' ')
if user.check_password(passwd):
  ......
登入後複製

使用者需要修改密碼的時候首先要讓他輸入原來的密碼,如果給定的字串通過了密碼檢查,回傳  True

使用set_password()來修改密碼

user = User.objects.get(username='')
user.set_password(password='')
user.save 
登入後複製

2.5 、簡單範例

註冊:

##
def sign_up(request):
 
  state = None
  if request.method == 'POST':
 
    password = request.POST.get('password', '')
    repeat_password = request.POST.get('repeat_password', '')
    email=request.POST.get('email', '')
    username = request.POST.get('username', '')
    if User.objects.filter(username=username):
        state = 'user_exist'
    else:
        new_user = User.objects.create_user(username=username, password=password,email=email)
        new_user.save()
 
        return redirect('/book/')
  content = {
    'state': state,
    'user': None,
  }
  return render(request, 'sign_up.html', content)  
登入後複製

修改密碼:

@login_required
def set_password(request):
  user = request.user
  state = None
  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):
      if not new_password:
        state = 'empty'
      elif new_password != repeat_password:
        state = 'repeat_error'
      else:
        user.set_password(new_password)
        user.save()
        return redirect("/log_in/")
    else:
      state = 'password_error'
  content = {
    'user': user,
    'state': state,
  }
  return render(request, 'set_password.html', content)
登入後複製

#自己建立User表 要注意的是,以上的所有操作,都是針對django自動建立的auth_user表的,我們可以看一下這張表的結構

這是django給我們自動建立的一張user表,而如果要用auth模組,就必須使用(或繼承)這張表。

继承表的好处是我们可以增加一些自己需要的字段,并且同时可以使用auth模块提供的接口、方法

下面就讲一下继承auth的方法:

1、导入AbstractUser类,并且写一个自定义的类,继承AbstractUser类,如下:

from django.contrib.auth.models import AbstractUser

class UserInfo(AbstractUser):
  """
  用户信息
  """
  nid = models.AutoField(primary_key=True)
  telephone = models.CharField(max_length=11, null=True, unique=True)
  ......
登入後複製

需要注意的是,UserInfo表里就不需要有auth_user里重复的字段了,比如说username以及password等,但是还是可以直接使用这些字段的,并且django会自动将password进行加密

2、这样写完之后,还需要在setting.py文件里配置:

AUTH_USER_MODEL = 'blog.UserInfo'
登入後複製

这样,django就知道从blog项目下的models去查找UserInfo这张表了

相关推荐:

Django的cookie使用详解

Django中的Ajax使用方法

以上是詳解Django之auth模組(用戶認證)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板