本文介绍: Django除了提供身份登录和注销视图,还提供了密码修改和重置的视图。
Django除了提供身份登录和注销视图,还提供了密码修改和重置的视图。
目录
关于Django身份验证更多内容,请查看
修改密码视图
集成Django的身份验证视图来修改密码。
打开account应用的urls.py文件,添加如下URL模式:
path("password_change/",
auth_views.PasswordChangeView.as_view(),
name='password_change'),
path("password_change/done/",
auth_views.PasswordChangeDoneView.as_view(),
name='password_change_done'),
PasswordChangeView视图将处理表单以更改密码
PasswordChangeDoneView视图将在用户成功更改密码后显示成功消息。
重置密码视图
打开account应用的urls.py文件,添加如下URL模式:
path("password_change/",
auth_views.PasswordChangeView.as_view(),
name='password_change'),
path("password_change/done/",
auth_views.PasswordChangeDoneView.as_view(),
name='password_change_done'),
path('password_reset/',a
uth_views.PasswordResetView.as_view(),
name='password_reset'),
path('reset/<uidb64>/<token>',
auth_views.PasswordResetConfirmView.as_view(),
name='password_reset_confirm'),
path('reset/done/',
auth_views.PasswordResetCompleteView.as_view(),
name='password_reset_complete'),
密码重置会给用户发送Email,用户点击Email中的链接跳转到新密码输入页面。
关于Django邮件发送设置,编辑setting.py
# 发送邮件配置
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
# smpt服务地址,示例为QQ邮箱
EMAIL_HOST = 'smtp.qq.com'
EMAIL_PORT = 25 # 端口默认都是25不需要修改
# 发送邮件的邮箱,需要配置开通SMTP
EMAIL_HOST_USER = youremailaddress
# 在邮箱中设置的客户端授权密码
# 此处的EMAIL_HOST_PASSWORD是用QQ邮箱授权码登录
EMAIL_HOST_PASSWORD = youremailkey
# 收件人看到的发件人
DEFAULT_FROM_EMAIL = youremailaddress
关于Django发送邮件更多内容,请查看Django发送QQ邮件-CSDN博客
自定义模版
以上视图会使用Django后管的系统模版,可以通过template_name参数替换为自己的模版。
比如替换密码修改的模版,在as_view括号中添加模版路径:
path("password_change/",
auth_views.PasswordChangeView.as_view(template_name='account/password_change_form.html'),
name='password_change')
关于Django身份验证更多内容,请查看
原文地址:https://blog.csdn.net/Q1780020/article/details/135565839
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_57598.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。