Django除了提供身份登录和注销视图,还提供了密码修改和重置的视图。
目录
关于Django身份验证更多内容,请查看
修改密码视图
集成Django的身份验证视图来修改密码。
打开account应用的urls.py文件,添加如下URL模式:
python
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模式:
python
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
python
# 发送邮件配置
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括号中添加模版路径:
python
path("password_change/",
auth_views.PasswordChangeView.as_view(template_name='account/password_change_form.html'),
name='password_change')
关于Django身份验证更多内容,请查看