1. 程式人生 > 程式設計 >django框架auth模組用法例項詳解

django框架auth模組用法例項詳解

本文例項講述了django框架auth模組用法。分享給大家供大家參考,具體如下:

auth模組的匯入

from django.contrib import auth

django中的auth模組有其自己完整的一套方法: 登入驗證、登出、使用者的建立、比較使用者輸入的密碼是否和資料庫的一致、使用者資訊的修改

1 我們來生成db.sqlite3 (migrations,migrate),開啟,從中我們可以找到表 auth_user,整篇都是圍繞這個表進行的

2 這個表裡面暫時是空的,我們可以建立 ,例如:建立一個超級使用者

我們從表auth_user 中可以看到生成了一條記錄,裡面的密碼是經過加密的

3 建立一個登入檢視和模板

上面的 authenticate方法

user = authenticate(username='someone',password='somepassword') 必須要有username和password

4 使用者的登出 logout

def log_out(request):
 auth.logout(request) #使用 logout 方法
 return redirect("/login/")

5 給使用者增加一個修改密碼的功能

def set_password(request):
 user=request.user
 state=""
 if request.method=="POST":
 oldpassword=request.POST.get('oldpassword','')
 newpassword=request.POST.get('newpassword','')
 repeatpassword=request.POST.get('repeatpassword','')

 if user.check_password(oldpassword):
  if not newpassword:
  state="新密碼不能為空"
  elif newpassword != repeatpassword:
  state="重置的密碼前後不一致"
  else:
  user.set_password(newpassword)
  user.save()
  return redirect("/login/")
 else:
  state="舊密碼輸入錯誤"

 return render(request,"set_password.html",{"state":state})

#模板
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>修改密碼</title>
</head>
<body>
<form action="" method="post">
 {% csrf_token %}
 <div>使用者:{{ user }}</div>
 <div>舊密碼 <input type="text" name="oldpassword"></div>
 <div>新密碼 <input type="text" name="newpassword"></div>
 <div>確認新密碼 <input type="text" name="repeatpassword"></div>
 <div><input type="submit"> <span>{{ state }}</span></div>
</form>
</body>
</html>

check_password() 驗證使用者輸入的密碼是否和資料庫中的一致 ,一致返回True,否則返回None

6 模擬登入將index作為首頁,根據使用者的登入與否選擇不同的頁面

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
</head>
<body>
<h1>index</h1>
<p>hello {{ user }}</p>

{% if request.user.is_authenticated %}
 <a href="/logout/" rel="external nofollow" >登出</a>
 <a href="/set_password/" rel="external nofollow" >修改密碼</a>
{% else %}
 <div><span>未登入</span></div>
 <p><a href="/login/" rel="external nofollow" >登陸</a></p>
 <p><a href="/reg/" rel="external nofollow" >註冊</a></p>
{% endif %}
</body>
</html>

未登入時

嘗試登入之後

下面修改密碼報錯情況

總結:

匯入:from django.contrib import auth

驗證使用者登入:user = authenticate(username='someone',password='somepassword')驗證成功返回user物件,否則返回none

session的寫操作: auth.login(request,user) #session的寫操作 對應於django_session表

使用者的登出或者登出:auth.logout(request)

驗證使用者是否已經登入:# user=request.user # if not user.is_authenticated(): return redirect("/login/")

驗證使用者輸入的密碼是否與資料庫一致:

user=request.user
user.check_password(oldpassword) 成功返回True,否則為None

修改密碼:

user = User.objects.get(username='') #先獲得user物件
user.set_password(password='')
user.save 

建立使用者,必須要有兩個資訊,使用者名稱和密碼

from django.contrib.auth.models import User
user = User.objects.create_user(username='',password='',email='')

希望本文所述對大家基於Django框架的Python程式設計有所幫助。