Django用戶身份驗(yàn)證完成示例代碼
在這篇Django文章中,wom 將討論Django User 驗(yàn)證,Django附帶了一個(gè)用戶認(rèn)證系統(tǒng)。 它處理用戶帳戶,組,權(quán)限和基于cookie的用戶會(huì)話。 Django身份驗(yàn)證系統(tǒng)同時(shí)處理身份驗(yàn)證和授權(quán)。 簡(jiǎn)要地說,身份驗(yàn)證將驗(yàn)證用戶是他們聲稱的身份,而授權(quán)則確定允許經(jīng)過身份驗(yàn)證的用戶執(zhí)行的操作。
基本上,我們將創(chuàng)建登錄,注銷,忘記密碼和重置密碼功能。
身份驗(yàn)證支持在django.contrib.auth中為Django contrib模塊。默認(rèn)情況下,所需的配置已包含在django-admin startproject生成的settings.py中,它們由INSTALLED_APPS設(shè)置中列出的兩項(xiàng)組成:
1、“ django.contrib.auth”包含身份驗(yàn)證框架的核心及其默認(rèn)模型。
2、“ django.contrib.contenttypes”是Django內(nèi)容類型系統(tǒng),它允許將權(quán)限與您創(chuàng)建的模型相關(guān)聯(lián)。
以及MIDDLEWARE設(shè)置中的這些項(xiàng)目:
1、SessionMiddleware管理跨請(qǐng)求的會(huì)話。
2、AuthenticationMiddleware使用會(huì)話將用戶與請(qǐng)求相關(guān)聯(lián)。
有了這些設(shè)置后,運(yùn)行命令manage.py migrate將為auth相關(guān)模型創(chuàng)建必要的數(shù)據(jù)庫表,并為已安裝的應(yīng)用程序中定義的任何模型創(chuàng)建權(quán)限。
Django提供以下基于類的視圖來處理身份驗(yàn)證。它們?nèi)课挥赿jango.contrib.auth.views中:
LoginView:處理登錄表單并登錄用戶
LogoutView:注銷用戶
PasswordChangeView:處理表單以更改用戶密碼
PasswordChangeDoneView:用戶成功重定向到的視圖 PasswordResetView:允許用戶重置其密碼。 它
生成帶有令牌的一次性使用鏈接并將其發(fā)送給
用戶的電子郵件帳戶。
首先我們需要?jiǎng)?chuàng)建一個(gè)新的project工程:
django-admin startproject MyProject #app python manage.py startapp MyApp #migrate python manage.py migrate #create a superuser python manage.py createsuperuser
Login & LogoutView
首先,您需要在創(chuàng)建的應(yīng)用程序中創(chuàng)建一個(gè)新的urls.py,并將其添加到您的文件中。
from django.urls import path, include from django.views.generic.base import TemplateView urlpatterns = [ path('accounts/', include('django.contrib.auth.urls')), path('', TemplateView.as_view(template_name = 'home.html'), name = 'home') ]
然后在主project下urls.py文件添加如下:
from django.contrib import admin from django.urls import path, include urlpatterns = [ path('admin/', admin.site.urls), path('', include('MyApp.urls')) ]
在帳戶應(yīng)用程序的template目錄中創(chuàng)建一個(gè)新目錄,并將其命名為registration。 這是Django身份驗(yàn)證視圖期望身份驗(yàn)證模板所處的默認(rèn)路徑。
django.contrib.admin模塊包含一些用于管理站點(diǎn)的身份驗(yàn)證模板。 我們已將帳戶應(yīng)用程序放置在INSTALLED_APPS設(shè)置的頂部,以便Django默認(rèn)使用我們的模板,而不使用其他應(yīng)用程序中定義的任何身份驗(yàn)證模板。
在templates / registration目錄中創(chuàng)建一個(gè)新文件,將其命名為login.html,并向其中添加以下代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Login</title> </head> <body> <h2>Login</h2> <p>Please login with your valid credentials</p> <form action="" method="post" novalidate> {% csrf_token %} {{form.as_p}} <input type="submit" value="Login"> </form> <p><a href="{% url 'password_reset' %}">Reset Password</a> </p> </body> </html>
Django默認(rèn)使用django.contrib.auth.forms中的AuthenticationForm表單。 如果登錄失敗,則此表單嘗試對(duì)用戶進(jìn)行身份驗(yàn)證并引發(fā)驗(yàn)證錯(cuò)誤。
另外,我們已經(jīng)在頂部添加了home.html網(wǎng)址。 您需要在注冊(cè)文件夾之外創(chuàng)建該文件,只需要在主模板中添加該文件,這些就是我們要添加到模板文件夾中的文件。 基本上,home.html用于重定向成功的登錄。
這是base.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> {% block body %} {% endblock %} </body> </html>
home.html代碼如下:
{% block body %} {% if user.is_authenticated %} Welcome {{user.username}} <p><a href="{% url 'logout' %}">Logout</a> </p> {% else %} <p><a href="{% url 'login' %}" >Login</a></p> {% endif %} {% endblock %}
基本上,我們將驗(yàn)證使用是否有效。
編輯項(xiàng)目的settings.py文件,并向其中添加以下代碼:
LOGIN_REDIRECT_URL = '/' LOGOUT_REDIRECT_URL = '/'
LOGIN_REDIRECT_URL:如果請(qǐng)求中沒有下一個(gè)參數(shù),則告訴Django成功登錄后重定向哪個(gè)URL
LOGOUT_URL:用于重定向用戶以注銷的URL
密碼修改
這些是我們更改密碼的文件。 將這些文件添加到template / registration文件夾中。
password_change_form.html
{% extends 'base.html' %} {% block body %} <h1>Change The Password</h1> <form action="" method="post"> {% csrf_token %} {{form.as_p}} <input type="submit" value="Change Password"> </form> {% endblock %}
password_change_done.html
{% extends 'base.html' %} {% block body %} <h1>Password Change Done</h1> <p>Your password changed successfully</p> {% endblock %}
重設(shè)密碼
在帳戶應(yīng)用程序的templates / registration /目錄中添加一個(gè)新文件,并將其命名為password_reset_form.html。 向其添加以下代碼:
password_reset_form.html
{% extends 'base.html' %} {% block body %} <h1>Password Reset Complete</h1> <p> Your password has been sent, you can <a href="{% url 'login' %}">Login</a> now </p> {% endblock %}
現(xiàn)在,在同一目錄中創(chuàng)建另一個(gè)文件,并將其命名為password_reset_email.html。 向其添加以下代碼:
{% extends 'base.html' %} {% block body %} Password reset for emal . {{email}} . follow the link {{protocol}}://{{domain}}{% url 'password_reset_confirm' uidb64=uid token=token %} {% endblock %}
password_reset_email.html模板將用于呈現(xiàn)發(fā)送給用戶的電子郵件,以重置其密碼。
在同一目錄中創(chuàng)建另一個(gè)文件,并將其命名為password_reset_done.html。 向其添加以下代碼:
{% extends 'base.html' %} {% block body %} <h1>Password Reset Done</h1> We have emailed your instructions for setting your password. {% endblock %}
在同一目錄中創(chuàng)建另一個(gè)模板,并將其命名為password_reset_confirm.html。 向其添加以下代碼:
{% extends 'base.html' %} {% block body %} <h1>Password Reset</h1> {% if validlink %} <form action="" method="post"> {% csrf_token %} {{form.as_p}} <input type="submit" value="Reset Password"> </form> {% else %} <p>Password reset email link was invalid, you can request a new one .</p> {% endif %} {% endblock %}
我們檢查提供的鏈接是否有效。 視圖PasswordResetConfirmView會(huì)設(shè)置此變量,并將其放在password_reset_confirm.html模板的上下文中。 如果鏈接有效,則顯示用戶密碼重置表格。
創(chuàng)建另一個(gè)模板,并將其命名為password_reset_complete.html。 在其中輸入以下代碼:
{% extends 'base.html' %} {% block body %} <h1>Password Reset Complete</h1> <p> Your password has been sent, you can <a href="{% url 'login' %}">Login</a> now </p> {% endblock %}
在settings.py文件中加入email的信息:
if not DEBUG: EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' EMAIL_HOST_USER = "parwizforogh0@gmail.com" EMAIL_HOST = 'smtp.gmail.com' EMAIL_PORT = 587 EMAIL_USE_TLS = True EMAIL_HOST_PASSWORD = "Your Password" else: EMAIL_BACKEND = ( "django.core.mail.backends.console.EmailBackend" )
啟動(dòng)工程,打開頁面:
https://codeloop.org/wp-content/uploads/2020/03/django_login.png
登錄:
登錄成功:
到此這篇關(guān)于Django用戶身份驗(yàn)證完成示例代碼的文章就介紹到這了,更多相關(guān)Django 身份驗(yàn)證 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中slice參數(shù)過長的處理方法及實(shí)例
在本篇文章里小編給大家分享了一篇關(guān)于python中slice參數(shù)過長的處理方法及實(shí)例內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。2020-12-12python內(nèi)置函數(shù)delattr()與dict()舉例詳解
這篇文章主要介紹了關(guān)于python內(nèi)置函數(shù)delattr()與dict()的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08Appium自動(dòng)化測(cè)試實(shí)現(xiàn)九宮格解鎖
本文主要介紹了Appium自動(dòng)化測(cè)試實(shí)現(xiàn)九宮格解鎖,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02linux環(huán)境打包python工程為可執(zhí)行程序的過程
本次需求,在ubuntu上面開發(fā)的python代碼程序需要打包成一個(gè)可執(zhí)行程序然后交付給甲方,因?yàn)椴荒苤苯咏o源碼給甲方,所以尋找方法將python開發(fā)的源碼打包成一個(gè)可執(zhí)行程序,本次在ubuntu上打包python源碼的方法和在window上打包的有點(diǎn)類似,感興趣的朋友跟隨小編一起看看吧2024-01-01Django數(shù)據(jù)庫表反向生成實(shí)例解析
這篇文章主要介紹了Django數(shù)據(jù)庫表反向生成實(shí)例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02