Django用戶身份驗證完成示例代碼
在這篇Django文章中,wom 將討論Django User 驗證,Django附帶了一個用戶認證系統。 它處理用戶帳戶,組,權限和基于cookie的用戶會話。 Django身份驗證系統同時處理身份驗證和授權。 簡要地說,身份驗證將驗證用戶是他們聲稱的身份,而授權則確定允許經過身份驗證的用戶執行的操作。
基本上,我們將創建登錄,注銷,忘記密碼和重置密碼功能。
身份驗證支持在django.contrib.auth中為Django contrib模塊。默認情況下,所需的配置已包含在django-admin startproject生成的settings.py中,它們由INSTALLED_APPS設置中列出的兩項組成:
1、“ django.contrib.auth”包含身份驗證框架的核心及其默認模型。
2、“ django.contrib.contenttypes”是Django內容類型系統,它允許將權限與您創建的模型相關聯。
以及MIDDLEWARE設置中的這些項目:
1、SessionMiddleware管理跨請求的會話。
2、AuthenticationMiddleware使用會話將用戶與請求相關聯。
有了這些設置后,運行命令manage.py migrate將為auth相關模型創建必要的數據庫表,并為已安裝的應用程序中定義的任何模型創建權限。
Django提供以下基于類的視圖來處理身份驗證。它們全部位于django.contrib.auth.views中:
LoginView:處理登錄表單并登錄用戶 LogoutView:注銷用戶
PasswordChangeView:處理表單以更改用戶密碼 PasswordChangeDoneView:用戶成功重定向到的視圖 PasswordResetView:允許用戶重置其密碼。 它 生成帶有令牌的一次性使用鏈接并將其發送給 用戶的電子郵件帳戶。
首先我們需要創建一個新的project工程:
django-admin startproject MyProject#apppython manage.py startapp MyApp #migratepython manage.py migrate #create a superuserpython manage.py createsuperuser
Login & LogoutView
首先,您需要在創建的應用程序中創建一個新的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’))]
在帳戶應用程序的template目錄中創建一個新目錄,并將其命名為registration。 這是Django身份驗證視圖期望身份驗證模板所處的默認路徑。
django.contrib.admin模塊包含一些用于管理站點的身份驗證模板。 我們已將帳戶應用程序放置在INSTALLED_APPS設置的頂部,以便Django默認使用我們的模板,而不使用其他應用程序中定義的任何身份驗證模板。
在templates / registration目錄中創建一個新文件,將其命名為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.wxshucaidpc.com/bcjs/{% url ’password_reset’ %}'>Reset Password</a> </p> </body></html>
Django默認使用django.contrib.auth.forms中的AuthenticationForm表單。 如果登錄失敗,則此表單嘗試對用戶進行身份驗證并引發驗證錯誤。
另外,我們已經在頂部添加了home.html網址。 您需要在注冊文件夾之外創建該文件,只需要在主模板中添加該文件,這些就是我們要添加到模板文件夾中的文件。 基本上,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.wxshucaidpc.com/bcjs/{% url ’logout’ %}'>Logout</a> </p> {% else %} <p><a href='http://www.wxshucaidpc.com/bcjs/{% url ’login’ %}' >Login</a></p> {% endif %} {% endblock %}
基本上,我們將驗證使用是否有效。
編輯項目的settings.py文件,并向其中添加以下代碼:
LOGIN_REDIRECT_URL = ’/’LOGOUT_REDIRECT_URL = ’/’
LOGIN_REDIRECT_URL:如果請求中沒有下一個參數,則告訴Django成功登錄后重定向哪個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 %}
重設密碼
在帳戶應用程序的templates / registration /目錄中添加一個新文件,并將其命名為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.wxshucaidpc.com/bcjs/{% url ’login’ %}'>Login</a> now </p>{% endblock %}
現在,在同一目錄中創建另一個文件,并將其命名為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模板將用于呈現發送給用戶的電子郵件,以重置其密碼。
在同一目錄中創建另一個文件,并將其命名為password_reset_done.html。 向其添加以下代碼:
{% extends ’base.html’ %} {% block body %} <h1>Password Reset Done</h1> We have emailed your instructions for setting your password. {% endblock %}
在同一目錄中創建另一個模板,并將其命名為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會設置此變量,并將其放在password_reset_confirm.html模板的上下文中。 如果鏈接有效,則顯示用戶密碼重置表格。
創建另一個模板,并將其命名為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.wxshucaidpc.com/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' )
啟動工程,打開頁面:
https://codeloop.org/wp-content/uploads/2020/03/django_login.png
登錄:
登錄成功:
到此這篇關于Django用戶身份驗證完成示例代碼的文章就介紹到這了,更多相關Django 身份驗證 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: