Django发送邮件和itsdangerous模块的配合使用解析


Posted in Python onAugust 10, 2019

项目需求:用户注册页面注册之后,系统会发送一封邮件到用户邮箱,用户点击链接以激活账户,其中链接中的用户信息需要加密处理一下

其中激活自己邮箱的smtp服务的操作就不在加以说明,菜鸟教程上有非常清晰的讲解,也可以去网上搜索详细步骤

首先在Django项目的settings文件中配置发送邮件相关的配置如下:

# 固定写法
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
# smtp服务器地址
EMAIL_HOST = 'smtp.qq.com'
# 固定端口号
EMAIL_PORT = 25
#发送邮件的邮箱
EMAIL_HOST_USER = '2746565701@qq.com'
#在邮箱中设置的客户端授权密码
EMAIL_HOST_PASSWORD = 'ytnvwapcbxmcdfig'
#收件人看到的发件人,尖括号中的必须与上面的user一致
EMAIL_FROM = '天天生鲜<2746565701@qq.com>'

用户模块的views.py文件关于itsdangerous和邮件发送的代码如下,项目其它部分的操作代码这里全部删除,这里使用的是基于类的视图:

基本逻辑:

  • 利用itsdangerous模块对链接中的用户信息加密,生成加密后的用户信息token;
  • 调用Django发送邮件的相关方法,进行发送邮件(邮件的配置已经配置好);
  • 邮件发送的链接中有一个可变参数,包含着用户id加密后的信息;
  • 用户接收到邮件之后,点击链接,跳转到对应的视图类进行处理;
  • 负责激活的视图类,解密用户的信息,获取用户id,查询到对应用户(在这个过程会判断被加密的信息是否超时);
  • 将对应用户中数据库中用户表中 is_active 字段的值改为1,表示此用户被激活;
  • 跳转到首页;
# 导入itsdangerous中要用到的加密类
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
# 导入itsdangerous中超时的异常
from itsdangerous import SignatureExpired
# 导入配置文件
from django.conf import settings
# 导入Django中的发送邮件的方法
from django.core.mail import send_mail
from .models import User



# Create your views here.
class RegisterView(View):
  """注册"""
  ....................
   
  def post(self, request):
    """进行注册处理"""  

    # 发送激活邮件,包含一个激活的链接:https://127.0.0.1:8000/user/active/3
    # 激活链接中需要包含用户的身份信息,并且要把身份信息进行加密

    # 加密用户的身份信息,生成激活的token
    serializer = Serializer(settings.SECRET_KEY, 3600) # 创建爱一个itsdangerous模块中加密类的对象,其中SECRET_KEY用settings中的,第二个参数为超时时间
    info = {'confirm': user.id} # 被加密的信息,一个字典,字典值为接收邮件用户的id
    # 利用dumps方法进行加密,加密后为bytes数据
    token = serializer.dumps(info) # bytes数据
    token = token.decode() # bytes转str
    # 发邮件
    subject = '天天生鲜欢迎信息' # 邮件主题
    message = '' 邮件信息,因为有html__message了,所以这里为空就好
    sender = settings.EMAIL_FROM # 发送者,直接从配置文件中导入上面配置的发送者
    receiver = [email] # 接收者的邮箱,是一个列表,这里是前端用户注册时传过来的 email
    # html结构的信息,其中包含了加密后的用户信息token
    html_message = '<h1>{},欢迎您成为天天生鲜注册会员</h1>请点击下面链接激活您的用户<br><a href="http:127.0.0.1:8000/user/active/{}" rel="external nofollow" >http:127.0.0.1:8000/user/active/{}</a>'.format(username, token, token)
    # 调用Django发送邮件的方法,这里传了5个参数
    send_mail(subject, message, sender, receiver, html_message=html_message)
    # 返回应答:跳转到首页
    return redirect(reverse('goods:index'))


class ActiveView(View):
  """用户激活"""
  def get(self, request, token):
    """进行用户激活"""
    # 进行解密,获取要激活的用户信息
    serializer = Serializer(settings.SECRET_KEY, 3600)
    try:
    # 通过itsdangerous模块的loads方法解密
      info = serializer.loads(token)
      # 获取待激活用户的id
      user_id = info.get('confirm')
      # 根据id获取用户信息
      user = User.objects.get(id=user_id)
      # 激活用户操作,将数据库中对应用户的is_active参数变为1
      user.is_active = 1
      user.save()
      # 跳转到登录界面
      return redirect(reverse('user:login'))
    except SignatureExpired as e:
      # 激活链接已经过期
      return HttpResponse('激活链接已过期!')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python 调用DLL操作抄表机
Jan 12 Python
Python中捕捉详细异常信息的代码示例
Sep 18 Python
Python最基本的输入输出详解
Apr 25 Python
python图片验证码生成代码
Jul 02 Python
python实现折半查找和归并排序算法
Apr 14 Python
Python图像的增强处理操作示例【基于ImageEnhance类】
Jan 03 Python
Python获取网段内ping通IP的方法
Jan 31 Python
Python 图像处理: 生成二维高斯分布蒙版的实例
Jul 04 Python
django的auth认证,authenticate和装饰器功能详解
Jul 25 Python
Python批量启动多线程代码实例
Feb 18 Python
jupyternotebook 撤销删除的操作方式
Apr 17 Python
Python 避免字典和元组的多重嵌套问题
Jul 15 Python
python requests库爬取豆瓣电视剧数据并保存到本地详解
Aug 10 #Python
python实现邮件发送功能
Aug 10 #Python
Python字典推导式将cookie字符串转化为字典解析
Aug 10 #Python
python selenium登录豆瓣网过程解析
Aug 10 #Python
python matplotlib库绘制散点图例题解析
Aug 10 #Python
python matplotlib库绘制条形图练习题
Aug 10 #Python
Python OpenCV实现鼠标画框效果
Aug 19 #Python
You might like
PHP生成静态页面详解
2006/12/05 PHP
php 遍历显示文件夹下所有目录、所有文件的函数,没有分页的代码
2008/11/14 PHP
php获取文件内容最后一行示例
2014/01/09 PHP
ThinkPHP实现简单登陆功能
2017/04/28 PHP
php和asp语法上的区别总结
2019/05/12 PHP
javascript demo 基本技巧
2009/12/18 Javascript
javascript 构建一个xmlhttp对象池合理创建和使用xmlhttp对象
2010/01/15 Javascript
mysql输出数据赋给js变量报unterminated string literal错误原因
2010/05/22 Javascript
js点击button按钮跳转到另一个新页面
2014/10/10 Javascript
使用变量动态设置js的属性名
2014/10/19 Javascript
ajax如何实现页面局部跳转与结果返回
2015/08/24 Javascript
简述Matlab中size()函数的用法
2016/03/20 Javascript
JavaScript事件学习小结(三)js事件对象
2016/06/09 Javascript
html、css和jquery相结合实现简单的进度条效果实例代码
2016/10/24 Javascript
WebStorm ES6 语法支持设置&amp;babel使用及自动编译(详解)
2017/09/08 Javascript
基于jquery实现五星好评
2017/11/18 jQuery
react-router4 配合webpack require.ensure 实现异步加载的示例
2018/01/18 Javascript
详解nodejs 配置文件处理方案
2019/01/02 NodeJs
微信小程序实现图片选择并预览功能
2019/07/25 Javascript
基于ts的动态接口数据配置的详解
2019/12/18 Javascript
Vue实现导航栏菜单
2020/08/19 Javascript
用python读写excel的方法
2014/11/18 Python
Python创建模块及模块导入的方法
2015/05/27 Python
用Django写天气预报查询网站
2018/10/21 Python
Python设计模式之迭代器模式原理与用法实例分析
2019/01/10 Python
Python实现多态、协议和鸭子类型的代码详解
2019/05/05 Python
python3实现高效的端口扫描
2019/08/31 Python
Window10下python3.7 安装与卸载教程图解
2019/09/30 Python
Pycharm编辑器功能之代码折叠效果的实现代码
2020/10/15 Python
python爬虫分布式获取数据的实例方法
2020/11/26 Python
收集的7个CSS3代码生成工具
2010/04/17 HTML / CSS
HTML5中微数据概述及在搜索引擎中的使用举例
2013/02/07 HTML / CSS
美国最大最全的亚洲购物网站:美国亚米网(Yamibuy)
2020/05/05 全球购物
最新会计专业求职信范文
2014/01/28 职场文书
2014年教师节寄语
2014/04/03 职场文书
2014教师年度工作总结
2014/11/10 职场文书