Django通用类视图实现忘记密码重置密码功能示例


Posted in Python onDecember 17, 2019

前言

在Django中有大量的通用类视图,例如ListView,DetailView,CreateView,UpdateView等等,将所有重复的增删改查代码抽象成一个通用类,只需要配置极少量的代码即可实现功能。

使用通用类视图完成找回密码功能

首先引入

from django.contrib.auth.views import PasswordResetView, PasswordResetConfirmView, \
 PasswordResetDoneView, PasswordChangeView, PasswordChangeDoneView, \
 PasswordResetCompleteView

配置如下:

class MyPasswordResetView(PasswordResetView):
 """重置密码视图"""
 template_name = 'users/registration/forget_pwd.html'
 form_class = ForgetForm
 success_url = reverse_lazy("users:password_reset_done")
 email_template_name = 'users/registration/password_reset_email.html'


class MyPasswordResetConfirmView(PasswordResetConfirmView):
 """重置密码页面,输入两次密码"""
 template_name = 'users/registration/password_change_form.html'
 success_url = reverse_lazy('users:password_reset_complete')


class MyPasswordResetDoneView(PasswordResetDoneView):
 """发送确认重置邮件"""
 template_name = 'users/registration/password_reset_done.html'


class MyPasswordResetCompleteView(PasswordResetCompleteView):
 """完成重置密码"""
 template_name = 'users/registration/password_change_done.html'

其中忘记密码,填写邮箱的模板forget_pwd.html模板如下:

<form method="post" class="form-validate" action="{% url 'users:password_reset' %}">
   <div class="form-group">
    <input id="login-username" type="text" name="email" required data-msg="请输入您的邮箱" class="input-material">
    <label for="login-username" class="label-material">邮箱</label>
    {% if form.errors %}
    <div style="color: red">邮箱输入错误</div>
    {% endif %}
   </div>

    {% csrf_token %}
    <button type="submit" id="login" href="#" rel="external nofollow" class="btn btn-primary">发送确认邮件</button>
   <!-- This should be submit button but I replaced it with <a> for demo purposes-->
   </form>

其中输入新密码模板password_change_form.html页面如下:

<form id="form" method="post">
 {% csrf_token %}
 {{ form|crispy }}
 <div class="form-group">
 <button type="submit" class="btn btn-primary button-submit">确认更改</button>
 </div>
</form>

其中重置密码邮件发送成功的模板password_reset_done.html如下:

<div class="col-lg-6 bg-white">
  <div class="form d-flex align-items-center">
  <div class="content">
   <h1>重置密码邮件发送成功!</h1>

  </div>
  </div>
 </div>

其中密码重置成功password_change_done.html如下:

<div class="container">
 <div class="row">
  <div class="col-md-6 offset-md-3">
  <h1>重置密码成功!</h1>
  <a href="{% url 'index' %}" rel="external nofollow" >回到首页</a>
  </div>
 </div>
 </div>

最后配置路由

path('password/reset/', view=MyPasswordResetView.as_view(), name='password_reset'), # password_reset
path('password/reset/done/', MyPasswordResetDoneView.as_view(), name='password_reset_done'), # password_reset_done

url(r'^reset/(?P<uidb64>[0-9A-Za-z_\-]+)/(?P<token>[0-9A-Za-z]{1,13}-[0-9A-Za-z]{1,20})/$',
 view=MyPasswordResetConfirmView.as_view(), name='password_reset_confirm'), # reset
path('reset/done/', MyPasswordResetCompleteView.as_view(), name='password_reset_complete'),

效果如下:

Django通用类视图实现忘记密码重置密码功能示例

Django通用类视图实现忘记密码重置密码功能示例

以上这篇Django通用类视图实现忘记密码重置密码功能示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python模拟登陆实现代码
Jun 14 Python
python3 实现对图片进行局部切割的方法
Dec 05 Python
Python+OpenCV感兴趣区域ROI提取方法
Jan 10 Python
详解python3 + Scrapy爬虫学习之创建项目
Apr 12 Python
python打造爬虫代理池过程解析
Aug 15 Python
python图形界面开发之wxPython树控件使用方法详解
Feb 24 Python
Python如何使用内置库matplotlib绘制折线图
Feb 24 Python
浅谈Keras中shuffle和validation_split的顺序
Jun 19 Python
Python实现打包成库供别的模块调用
Jul 13 Python
Python下载的11种姿势(小结)
Nov 18 Python
pip install命令安装扩展库整理
Mar 02 Python
使用Django框架创建项目
Jun 10 Python
Django集成celery发送异步邮件实例
Dec 17 #Python
python学生信息管理系统实现代码
Dec 17 #Python
pymysql模块的操作实例
Dec 17 #Python
Django异步任务线程池实现原理
Dec 17 #Python
python 求10个数的平均数实例
Dec 16 #Python
python 经典数字滤波实例
Dec 16 #Python
Python实现把类当做字典来访问
Dec 16 #Python
You might like
全国FM电台频率大全 - 24 贵州省
2020/03/11 无线电
memcached 和 mysql 主从环境下php开发代码详解
2010/05/16 PHP
为百度UE编辑器上传图片添加水印功能
2015/04/16 PHP
php mysql like 实现多关键词搜索的方法
2016/10/29 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
PHP实现随机发放扑克牌
2020/04/21 PHP
JS比较两个时间大小的简单示例代码
2013/12/20 Javascript
JS基于Ajax实现的网页Loading效果代码
2015/10/27 Javascript
功能强大的Bootstrap使用手册(一)
2016/08/02 Javascript
微信小程序 教程之注册程序
2016/10/17 Javascript
Jquery鼠标放上去显示全名的实现方法
2017/02/06 Javascript
ES6新特性二:Iterator(遍历器)和for-of循环详解
2017/04/20 Javascript
JavaScript30 一个月纯 JS 挑战中文指南(英文全集)
2017/07/23 Javascript
Node.js readline模块与util模块的使用
2018/03/01 Javascript
vue+axios实现文件下载及vue中使用axios的实例
2018/09/21 Javascript
jQuery事件多次绑定与解绑问题实例分析
2019/02/19 jQuery
nodejs微信开发之接入指南
2019/03/17 NodeJs
详解vuejs2.0 select 动态绑定下拉框支持多选
2019/04/25 Javascript
jQuery中DOM操作原则实例分析
2019/08/01 jQuery
[00:44]2016完美“圣”典 风云人物:Mikasa宣传片
2016/12/07 DOTA
全面了解python中的类,对象,方法,属性
2016/09/11 Python
使用Django启动命令行及执行脚本的方法
2018/05/29 Python
Python3.6实现带有简单界面的有道翻译小程序
2019/04/16 Python
详解用python生成随机数的几种方法
2019/08/04 Python
python实现批量修改服务器密码的方法
2019/08/13 Python
python编写计算器功能
2019/10/25 Python
python定时任务 sched模块用法实例
2019/11/04 Python
python 写一个性能测试工具(一)
2020/10/24 Python
python爬虫scrapy框架之增量式爬虫的示例代码
2021/02/26 Python
德国Discount-Apotheke中文官网:DC德式康线上药房
2020/02/18 全球购物
C#公司笔试题
2014/03/28 面试题
工作时间上网检讨书
2014/02/03 职场文书
《金孔雀轻轻跳》教学反思
2014/04/20 职场文书
初一数学教学反思
2016/02/17 职场文书
nginx配置虚拟主机的详细步骤
2021/07/21 Servers
python套接字socket通信
2022/04/01 Python