[py][mx]django注册-邮件激活

人生,学习,就是一段旅途, 说是放弃,其实是自信心作祟. 因为不同时间段状态,譬如晚上和早上刚来状态不一样.做相同事情容器失去自信而放弃. 坚持可以打破这个魔咒

还有就是有些问题得分割, 不要让压死牛的最后一跟稻草出现.

注册views

class RegisterView(View):
    def get(self, request):
        register_form = RegisterForm()  # 实例化register表单
        return render(request, 'register.html', {'register_form': register_form})

    def post(self, request):
        register_form = RegisterForm(request.POST)
        if register_form.is_valid():
            user_name = request.POST.get("email", "")  # 字典取值,如果无,赋值为空
            pass_word = request.POST.get("password", "")
            user_profile = UserProfile()
            user_profile.username = user_name
            user_profile.email = user_name
            user_profile.password = make_password(pass_word)  # 密码加密存储
            user_profile.is_active = False
            user_profile.save()
            # 发激活邮件
            send_register_email(user_name, "register")
            return render(request, 'login.html')
        else:
            return render(request, 'register.html', {'register_form': register_form})

发邮件配置

settings.py

EMAIL_HOST = "smtp.sina.com"
EMAIL_PORT = 25
EMAIL_HOST_USER = 'lanny@sina.com'
EMAIL_HOST_PASSWORD = '123456!'
EMAIL_USE_TLS = False
EMAIL_FROM = "lanny@sina.com"

创建utils文件夹,存放常用功能- 发邮件

1312420-20180202103128343-1994774900.png

email_send.py


#!/usr/bin/env python
# coding=utf-8
import string
from random import Random

from django.core.mail import send_mail
from users.models import EmailVerifyRecord
from mxonline.settings import EMAIL_FROM


def random_str(randomlength=8):#生成随机字符串用于激活链接后缀
    str = ''
    chars = string.ascii_letters
    length = len(chars) - 1
    random = Random()
    for i in range(randomlength):
        str += chars[random.randint(0, length)]
    return str


def send_register_email(email, send_type="register"):#根据注册类型: 注册or找回密码来判断发哪种邮件
    email_record = EmailVerifyRecord()#每次发邮件记录都记录在EmailVerifyRecord的模型中,用于激活时判断是否有
    code = random_str(16)
    email_record.code = code
    email_record.email = email
    email_record.send_type = send_type
    email_record.save()

    email_title = ""
    email_body = ""

    if send_type == "register": # 根据send_type定制发送内容
        email_title = "后台在线系统激活链接"
        email_body = "后台在线系统激活链接: http://127.0.0.1:8000/active/{}".format(code)
        send_status = send_mail(email_title, email_body, EMAIL_FROM, [email,])
        if send_status:
            pass

激活: 主要是修改UserProfile里的is_active字段

from users.models import UserProfile, EmailVerifyRecord
from utils.email_send import send_register_email

class ActiveView(View):#主要功能是修改user_profile里的is_active字段为1
    def get(self, request,active_code):
        all_reocrds = EmailVerifyRecord.objects.filter(code=active_code)
        if all_reocrds:
            for record in all_reocrds:
                email = record.email
                user = UserProfile.objects.get(email=email)
                user.is_active = True
                user.save()
        return render(request, 'login.html')

urls配置


urlpatterns = [
    path('active/<str:active_code>/', views.ActiveView.as_view(), name="active"),
    path('xadmin/', xadmin.site.urls),
    path('captcha/', include('captcha.urls')),
]

激活邮件: 注册后会收到激活邮件, 注册如果字段不合法不会发邮件.

1312420-20180202104006546-91060847.png

1312420-20180202104038468-1755691689.png

django2.0的url兼容1.x的.不过推荐用path

参考

from django.conf.urls import url
def year_archive(request, year):
    year = int(year) # convert str to int
    # Get articles from database
def detail_view(request, article_id):
    pass
def edit_view(request, article_id):
    pass
def delete_view(request, article_id):
    pass
urlpatterns = [
    url('articles/(?P<year>[0-9]{4})/', year_archive),
    url('article/(?P<article_id>[a-zA-Z0-9]+)/detail/', detail_view),
    url('articles/(?P<article_id>[a-zA-Z0-9]+)/edit/', edit_view),
    url('articles/(?P<article_id>[a-zA-Z0-9]+)/delete/', delete_view),
]
from django.urls import path
from . import views
urlpatterns = [
    path('articles/2003/', views.special_case_2003),
    path('articles/<int:year>/', views.year_archive),
    path('articles/<int:year>/<int:month>/', views.month_archive),
    path('articles/<int:year>/<int:month>/<slug>/', views.article_detail),
]
Django默认支持以下5个转化器: 还可以自定义, 这里就不讨论了

str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
int,匹配正整数,包含0。
slug,匹配字母、数字以及横杠、下划线组成的字符串。
uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
path,匹配任何非空字符串,包含了路径分隔符

转载于:https://www.cnblogs.com/iiiiiher/p/8403931.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值