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中:
- LoginView:处理登录表单并登录用户
LogoutView:注销用户
PasswordChangeView:处理表单以更改用户密码
PasswordChangeDoneView:用户成功重定向到的视图 - PasswordResetView:允许用户重置其密码。它
生成带有令牌的一次性使用链接并将其发送给
用户的电子邮件帐户。
django-admin startproject MyProject#apppython manage.py startapp MyApp#migratepython manage.py migrate#create a superuserpython manage.py createsuperuserLogin & 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
LoginPlease login with your valid credentials
{% csrf_token %} {{form.as_p}} Reset Password
Django默认使用django.contrib.auth.forms中的AuthenticationForm表单。如果登录失败,则此表单尝试对用户进行身份验证并引发验证错误。另外,我们已经在顶部添加了home.html网址。您需要在注册文件夹之外创建该文件,只需要在主模板中添加该文件,这些就是我们要添加到模板文件夹中的文件。基本上,home.html用于重定向成功的登录。这是base.html Titletitle> head>{% 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
Change The Password {% csrf_token %} {{form.as_p}} {% endblock %}password_change_done.html{% extends 'base.html' %}{% block body %}Password Change Done
Password Change DoneYour password changed successfully
{% endblock %}重设密码在帐户应用程序的templates / registration /目录中添加一个新文件,并将其命名为password_reset_form.html。向其添加以下代码:password_reset_form.html
{% extends 'base.html' %}{% block body %}Password Reset Complete
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
Password Reset DoneWe have emailed your instructions for setting your password.{% endblock %}在同一目录中创建另一个模板,并将其命名为password_reset_confirm.html。向其添加以下代码:{% extends 'base.html' %}{% block body %}Password Reseth1>
{% if validlink %} {% csrf_token %} {{form.as_p}} form>{% else %}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 %}Password Reset Completeh1>
Your password has been sent, you can 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" )启动工程,打开页面测试:
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
