forms身份验证 不跳转_Django用户身份验证实战
生活随笔
收集整理的這篇文章主要介紹了
forms身份验证 不跳转_Django用户身份验证实战
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在這篇Django文章中,我們?將討論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中:
LOGOUT_URL:用于重定向用戶以注銷的URL密碼修改
這些是我們更改密碼的文件。將這些文件添加到template / registration文件夾中。password_change_form.html{%?extends?'base.html'?%}{% block body %}
在帳戶應用程序的templates / registration /目錄中添加一個新文件,并將其命名為password_reset_form.html。向其添加以下代碼:password_reset_form.html{% extends 'base.html' %}{% block body %}
2、“ django.contrib.contenttypes”是Django內容類型系統,它允許將權限與您創建的模型相關聯。
以及MIDDLEWARE設置中的這些項目:1、SessionMiddleware管理跨請求的會話。
2、AuthenticationMiddleware使用會話將用戶與請求相關聯。
有了這些設置后,運行命令manage.py migrate將為auth相關模型創建必要的數據庫表,并為已安裝的應用程序中定義的任何模型創建權限。Django提供以下基于類的視圖來處理身份驗證。它們全部位于django.contrib.auth.views中:
- LoginView:處理登錄表單并登錄用戶
LogoutView:注銷用戶
PasswordChangeView:處理表單以更改用戶密碼
PasswordChangeDoneView:用戶成功重定向到的視圖 - PasswordResetView:允許用戶重置其密碼。它
生成帶有令牌的一次性使用鏈接并將其發送給
用戶的電子郵件帳戶。
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, includeurlpatterns = [ path('admin/', admin.site.urls), path('', include('MyApp.urls'))]在帳戶應用程序的template目錄中創建一個新目錄,并將其命名為registration。這是Django身份驗證視圖期望身份驗證模板所處的默認路徑。django.contrib.admin模塊包含一些用于管理站點的身份驗證模板。我們已將帳戶應用程序放置在INSTALLED_APPS設置的頂部,以便Django默認使用我們的模板,而不使用其他應用程序中定義的任何身份驗證模板。在templates / registration目錄中創建一個新文件,將其命名為login.html,并向其中添加以下代碼: LoginLogin
Please login with your valid credentials
{% csrf_token %} {{form.as_p}}Reset Password
Django默認使用django.contrib.auth.forms中的AuthenticationForm表單。如果登錄失敗,則此表單嘗試對用戶進行身份驗證并引發驗證錯誤。另外,我們已經在頂部添加了home.html網址。您需要在注冊文件夾之外創建該文件,只需要在主模板中添加該文件,這些就是我們要添加到模板文件夾中的文件。基本上,home.html用于重定向成功的登錄。這是base.html<html lang="en"><head> <meta charset="UTF-8"> <title>Titletitle>head><body>{%?block?body?%}{% endblock %}body>html>home.heml{% block body %}{% if user.is_authenticated %}Welcome {{user.username}}Logout
{% else %}Login
{% endif %}{% endblock %}基本上,我們就可以驗證使用是否有效。編輯項目的settings.py文件,并向其中添加以下代碼:LOGIN_REDIRECT_URL = '/'LOGOUT_REDIRECT_URL = '/'LOGIN_REDIRECT_URL:如果請求中沒有下一個參數,則告訴Django成功登錄后重定向哪個URLLOGOUT_URL:用于重定向用戶以注銷的URL密碼修改
這些是我們更改密碼的文件。將這些文件添加到template / registration文件夾中。password_change_form.html{%?extends?'base.html'?%}{% block body %}
Change The Password
{% csrf_token %} {{form.as_p}} {% endblock %}password_change_done.html{%?extends?'base.html'?%}{% block body %}Password Change Done
Your password changed successfully
{% endblock %}重設密碼在帳戶應用程序的templates / registration /目錄中添加一個新文件,并將其命名為password_reset_form.html。向其添加以下代碼:password_reset_form.html{% extends 'base.html' %}{% block body %}
Password Reset Complete
Your password has been sent, you can Login now
{% 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 %}Password Reset Done
We have emailed your instructions for setting your password.{% endblock %}在同一目錄中創建另一個模板,并將其命名為password_reset_confirm.html。向其添加以下代碼:{% extends 'base.html' %}{% block body %}<h1>Password Reseth1>{% 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 Completeh1><p> Your password has been sent, you can <a href="{% url 'login' %}">Logina> now p>{% endblock %}在settings.py文件中加入email的信息:if not DEBUG: EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'??????EMAIL_HOST_USER?=?"test0@qq.com"??????EMAIL_HOST?=?'smtp.qq.com'??????EMAIL_PORT?=?25 EMAIL_USE_TLS = True EMAIL_HOST_PASSWORD = "Your Password"else: EMAIL_BACKEND = ( "django.core.mail.backends.console.EmailBackend" )啟動工程,打開頁面測試:總結
以上是生活随笔為你收集整理的forms身份验证 不跳转_Django用户身份验证实战的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python面试题及答案bt_公布上期P
- 下一篇: npoi 所有列调整为一页_必能用到,一