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)要地說(shuō),身份驗(yàn)證將驗(yàn)證用戶是他們聲稱(chēng)的身份,而授權(quán)則確定允許經(jīng)過(guò)身份驗(yàn)證的用戶執(zhí)行的操作。
基本上,我們將創(chuàng)建登錄,注銷(xiāo),忘記密碼和重置密碼功能。
身份驗(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)容類(lè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ù)庫(kù)表,并為已安裝的應(yīng)用程序中定義的任何模型創(chuàng)建權(quán)限。
Django提供以下基于類(lèi)的視圖來(lái)處理身份驗(yàn)證。它們?nèi)课挥赿jango.contrib.auth.views中:
LoginView:處理登錄表單并登錄用戶 LogoutView:注銷(xiāo)用戶
PasswordChangeView:處理表單以更改用戶密碼 PasswordChangeDoneView:用戶成功重定向到的視圖 PasswordResetView:允許用戶重置其密碼。 它 生成帶有令牌的一次性使用鏈接并將其發(fā)送給 用戶的電子郵件帳戶。
首先我們需要?jiǎng)?chuàng)建一個(gè)新的project工程:
django-admin startproject MyProject#apppython manage.py startapp MyApp #migratepython manage.py migrate #create a superuserpython manage.py createsuperuser
Login & LogoutView
首先,您需要在創(chuàng)建的應(yīng)用程序中創(chuàng)建一個(gè)新的urls.py,并將其添加到您的文件中。
from django.urls import path, includefrom django.views.generic.base import TemplateViewurlpatterns = [ path(’accounts/’, include(’django.contrib.auth.urls’)), path(’’, TemplateView.as_view(template_name = ’home.html’), name = ’home’) ]
然后在主project下urls.py文件添加如下:
from django.contrib import adminfrom 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='http://www.aoyou183.cn/bcjs/{% 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='http://www.aoyou183.cn/bcjs/{% url ’logout’ %}'>Logout</a> </p> {% else %} <p><a href='http://www.aoyou183.cn/bcjs/{% url ’login’ %}' >Login</a></p> {% endif %} {% endblock %}
基本上,我們將驗(yàn)證使用是否有效。
編輯項(xiàng)目的settings.py文件,并向其中添加以下代碼:
LOGIN_REDIRECT_URL = ’/’LOGOUT_REDIRECT_URL = ’/’
LOGIN_REDIRECT_URL:如果請(qǐng)求中沒(méi)有下一個(gè)參數(shù),則告訴Django成功登錄后重定向哪個(gè)URL
LOGOUT_URL:用于重定向用戶以注銷(xiāo)的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='http://www.aoyou183.cn/bcjs/{% 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='http://www.aoyou183.cn/bcjs/{% 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)工程,打開(kāi)頁(yè)面:
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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)2. 如何在jsp界面中插入圖片3. JSP數(shù)據(jù)交互實(shí)現(xiàn)過(guò)程解析4. PHP循環(huán)與分支知識(shí)點(diǎn)梳理5. XML基本概念XPath、XSLT與XQuery函數(shù)介紹6. AspNetCore&MassTransit Courier實(shí)現(xiàn)分布式事務(wù)的詳細(xì)過(guò)程7. jsp實(shí)現(xiàn)登錄界面8. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案9. ASP.NET泛型三之使用協(xié)變和逆變實(shí)現(xiàn)類(lèi)型轉(zhuǎn)換10. jsp+servlet簡(jiǎn)單實(shí)現(xiàn)上傳文件功能(保存目錄改進(jìn))
