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()方法及其配置 詳見上一篇博客

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM