django 开发忘记密码通过邮箱找回功能

一、流程分析:

1.点击忘记密码====》forget.html页面,输入邮箱和验证码,发送验证链接网址的邮件====》发送成功,跳到send_success.html提示

2.到邮箱里找到验证链接网址,访问重设密码网址reset.html===》重设密码提交数据,成功则返回首页,失败则返回错误信息

二、

1.users/forms.py文件中

from django import forms
from captcha.fields import CaptchaField


.......

#forget.html中,用于验证邮箱格式和验证码
class ForgetForm(forms.Form):
    email=forms.EmailField(required=True)
    captcha=CaptchaField(error_messages={'invalid':'验证码错误'})

#reset.html中,用于验证新设的密码长度是否达标
class ResetForm(forms.Form):
    newpwd1=forms.CharField(required=True,min_length=6,error_messages={'required': '密码不能为空.', 'min_length': "至少6位"})
    newpwd2 = forms.CharField(required=True, min_length=6, error_messages={'required': '密码不能为空.', 'min_length': "至少6位"})

2.users/views.py中相关代码:

......
from django.shortcuts import render,redirect
from django.http import HttpResponse
from users.form import ForgetForm,ResetForm
from .models import UserProfile
from django.contrib.auth.hashers import make_password
from apps.utils.email_send import send_register_email
from .models import EmailVerifyRecord

......

class ForgetPwdView(View):
    '''忘记密码'''
    def get(self,request):
        forget_form=ForgetForm()
        return render(request,'forget.html',{'forget_form':forget_form})
    def post(self,request):
        forget_form = ForgetForm(request.POST)
        if forget_form.is_valid():
            email=request.POST.get('email','')
            send_register_email(email,'forget')
            return render(request,'send_success.html')
        else:
            return render(request,'forget.html',{'forget_form':forget_form})



class ResetView(View):
    '''重置密码'''
    def get(self,request,active_code):
        record=EmailVerifyRecord.objects.filter(code=active_code)
        print(record)
        if record:
            for i in record:
                email=i.email
                is_register=UserProfile.objects.filter(email=email)
                if is_register:
                    return render(request,'pwd_reset.html',{'email':email})
        return redirect('index')



#因为<form>表单中的路径要是确定的,所以post函数另外定义一个类来完成
class ModifyView(View):
    """重置密码post部分"""
    def post(self,request):
        reset_form=ResetForm(request.POST)
        if reset_form.is_valid():
            pwd1=request.POST.get('newpwd1','')
            pwd2=request.POST.get('newpwd2','')
            email=request.POST.get('email','')
            if pwd1!=pwd2:
                return render(request,'pwd_reset.html',{'msg':'密码不一致!'})
            else:
                user=UserProfile.objects.get(email=email)
                user.password=make_password(pwd2)
                user.save()
                return redirect('index')
        else:
            email=request.POST.get('email','')
            return render(request,'pwd_reset.html',{'msg':reset_form.errors})

3.新建forget.html, success_send.html, pwd_reset.html

#forget.html

<!DOCTYPE html>
{% load staticfiles %}
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>忘记密码</title>

<style>
.out{
    width: 500px;
    height: 900px;
    margin: 0 auto;
    margin-top: 100px;
}
</style>
</head>
<body>


    <div class="out">
        <h1>真粗心,忘了密码吧?快通过邮箱找回密码吧!</h1>
        <form method="post" action="{% url 'forget_pwd' %}">
            <P><span>邮箱:</span><input type="text" name="email"></P>
            <P><span>验证码:</span>{{ forget_form.captcha }}</P>
            {% csrf_token %}
            <p><input type="submit" value="确认发送验证邮件"></p>
        </form>
        <h1>{{ forget_form.errors }}</h1>
    </div>


</body>
</html>

#success_send.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>发送邮件成功,快去邮箱查看吧!(收件箱没有,垃圾箱一定有……)</h1>
</body>
</html>

#pwd_reset.html

<!DOCTYPE html>
{% load staticfiles %}
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>重置密码</title>

<style>
.out{
    width: 500px;
    height: 900px;
    margin: 0 auto;
    margin-top: 100px;
}
</style>
</head>
<body>


    <div class="out">
        <h1>可以重新设置一个好记的新密码啦!</h1>
        <form method="post" action="{% url 'modify' %}">
            <P><span>新密码:</span><input type="password" name="newpwd1" placeholder="至少6位"></P>
            <P><span>确认新密码:</span><input type="password" name="newpwd2" placeholder="至少6位"></P>
            {% csrf_token %}
            <input type="hidden" name="email" value="{{ email }}">
            <p><input type="submit" value="确认"></p>
        </form>
        <h1>{{ msg }}</h1>
    </div>


</body>
</html>

4.配置相关的urls.py:

from users.views import ForgetPwdView,ResetView,ModifyView

......

urlpatterns = [
   .....

    #忘记密码
    path('forget/',ForgetPwdView.as_view(),name='forget_pwd'),
    #重置密码
    path('reset/<str:active_code>',ResetView.as_view(),name='reset'),
    path('modify/',ModifyView.as_view(),name='modify'),


   ......
]

运行项目,点击 忘记密码 链接(<a href="{% url 'forget_pwd' %}">忘记密码</a>),就可以完成通过邮箱找回密码的功能啦!

5.send_register_email()方法及其配置 详见上一篇博客

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏龙首琴剑庐

Zookeeper ACL权限配置及zkclient示例

zk做为分布式架构中的重要中间件,通常会在上面以节点的方式存储一些关键信息,默认情况下,所有应用都可以读写任何节点,在复杂的应用中,这不太安全,ZK通过ACL机...

89550
来自专栏优启梦

emlog后台登录失败邮件通知

前面说到emlog后台登录参数加密,下面我们说说如何给emlog添加后台登录失败邮件通知的功能,本次我们需要用到mail函数,当然也就是需要25端口发信,如果是...

656120
来自专栏Youngxj

emlog后台登录失败邮件通知

13630
来自专栏緣來來來

申请Let's Encrypt通配符证书

Let's Encrypt支持通配符证书了,也就是说你只需要为你的网站申请*.example.com这样一个证书,所有的子域名都可以支持,下面介绍下申请方法:

67320
来自专栏雪胖纸的玩蛇日常

django 通过ajax完成邮箱用户注册、激活账号

49570
来自专栏Java学习123

myeclipse10.7破解成功 但 无法打war包

34080
来自专栏云计算教程系列

如何在Ubuntu 14.04上将解析应用程序迁移到解析服务器

Parse是一个移动后端即服务平台,自2013年起由Facebook拥有。2016年1月,Parse宣布其托管服务将于2017年1月28日完全关闭。

5500
来自专栏云计算教程系列

如何在Ubuntu 18.04上为用户目录设置vsftpd

FTP是文件传输协议的缩写,是一种曾经广泛用于在客户端和服务器之间移动文件的网络协议。它已被更快,更安全,更方便的文件传输方式所取代。许多普通网民希望通过htt...

13900
来自专栏惨绿少年

SSH服务详解

第1章 SSH服务 1.1 SSH服务协议说明 SSH 是 Secure Shell Protocol 的简写,由 IETF 网络工作小组(Network Wo...

50500
来自专栏云计算教程系列

如何在Debian 9上使用Let加密来保护Nginx

我们的加密是一个证书颁发机构(CA),它提供了一种获取和安装免费TLS / SSL证书的简便方法,可以在Web服务器上启用加密的HTTPS。它通过提供软件客户端...

32240

扫码关注云+社区

领取腾讯云代金券