django+celery 实现pycharm发送邮箱

celery是什么

Celery介绍:

  1. 一个简单、灵活且可靠、处理大量消息的分布式系统,可以在一台或者多台机器上运行。
  2. 单个 Celery 进程每分钟可处理数以百万计的任务。
  3. 通过消息进行通信,使用消息队列(broker)在客户端和消费者之间进行协调
    ----在需要同时处理多个任务得时候选择celery--------

celery的操作步骤

  1. 下载celery:pip install -U Celery
  2. 在项目中创建celery_tasks包实现celery功能
  3. 创建main方法作为celery入口
  4. 在mian入口中,新建celery实例对象
from celery import Celery
celery_app = Celery('meiduo')
  1. 建立配置文件,即消息队列,新建config的py文件,使用redis数据库进行中间人,
broker_url = 'redis://127.0.0.1/10'
  1. 将配置文件导入main中
celery_app.config_from_object('celery_tasks.config')
  1. 新建具体任务,在celery_tasks包中新建你的任务包,在包中新建tasks任务py文件,设置edf方法即消费者需要执行的
  2. 在main中注册任务
celery_app.autodiscover_tasks(['celery_tasks.sms', 'celery_tasks.email'])
  1. 为celery使用django配置文件在main中进行设置
import os
if not os.getenv('DJANGO_SETTINGS_MODULE'):
    os.environ['DJANGO_SETTINGS_MODULE'] = 'meiduo_mall.settings.dev'
  1. 运行celery(注意:window操作系统使用的命令)
celery -A celery_tasks.main worker -l info --pool=solo

发送邮件

注册任意一个邮箱,开启他的
IMAP/SMTP服务
POP3/SMTP服务,在setting中配置你的邮件信息

EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'  # 指定邮件后端
EMAIL_HOST = 'smtp.yeah.net'  # 发邮件主机
EMAIL_PORT = 25  # 发邮件端口
EMAIL_HOST_USER = 'lxl1999999@yeah.net'  # 授权的邮箱
EMAIL_HOST_PASSWORD = '**********'  # 邮箱授权时获得的密码,非注册登录密码
EMAIL_FROM = 'xuliang<lxl1999999@yeah.net>'  # 发件人抬头

配置完成后在celery中导入send_mail方法调用即可发送邮件

from django.core.mail import send_mail
# send_mail('标题','普通文件正文','发件人','收件人','富文本正文')

将send_mail导入到view使用时记得要加delay

将邮件的内容完善

邮件的内容是一个连接,连接需要能够证明是登录的用户所点击的,需要在连接上设立一个能够进入网站的地址和一个token能够证明身份并加密token作为参数
在这里插入图片描述
前面的不变,拼接后面的token,

from itsdangerous import TimedJSONWebSignatureSerializer as Serializer


def generate_verify_email_url(user):
    s = Serializer(settings.SECRET_KEY, constants.VERIFY_EMAIL_TOKEN_EXPIRES)
    data = {
        'user_id': user.id,
        'email': user.email,
    }
    token = s.dumps(data)
    return settings.EMAIL_VERIFY_URL+'?token='+token.decode()

将id和email信息加密拼接url进行返回到view中

class EmailView(LoginRequiredJSONMixin, View):
    """添加邮箱"""
    def put(self, request):
        # 接受参数
        json_str = request.body.decode()
        json_dict = json.loads(json_str)
        email = json_dict.get('email')

        # 校验参数
        if not email:
            return http.HttpResponseForbidden('缺少email参数')
        if not re.match(r'^[a-z0-9][\w\.\-]*@[a-z0-9\-]+(\.[a-z]{2,5}){1,2}$', email):
            return http.HttpResponseForbidden('参数email有误')
        # 将用户传入的邮箱传入到数据库中的email字段中
        try:
            request.user.email = email
            request.user.save()  # 同步数据库
            # 发送邮箱验证
            verify_url = generate_verify_email_url(request.user)
            send_verify_email.delay(email, verify_url)

        except Exception as e:
            logger.error(e)
            return http.JsonResponse({'code':RETCODE.DBERR,'errmsg':'添加邮箱失败'})
        return http.JsonResponse({'code':RETCODE.OK,'errmsg':'OK'})

由于是在已有的表里做修改(给email字段里赋一个值),所以使用put方法

验证邮件

创建一个视图,url是邮件里发出的连接地址,得到参数token,验证token

url(r'^emails/verification/$', views.VerifyEmailView.as_view()),
class VerifyEmailView(View):
    def get(self,request):
        # 接受参数
        token = request.GET.get('token')
        if not token:
            return http.HttpResponseForbidden('缺少token')
        user = check_verify_email_token(token)
        if not user :
            return http.HttpResponseBadRequest('无效的token')
        # 将数据库的email_active设为ture
        try:
            user.email_active = True
            user.save()
        except Exception as e:
            logger.error(e)
            return http.HttpResponseServerError('激活邮箱失败')
        # 返回邮箱验证结果
        return redirect(reverse('users:info'))

验证通过,将数据库的email_active改为True,前端发送验证邮箱按钮变为已验证

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值