Django之使用内置函数和celery发邮件的方法示例
作者:YifChan 发布时间:2022-03-04 17:15:26
邮箱配置
开启stmp服务
以163邮箱为例,点击设置里面的stmp
开启客户端授权密码
如上所示,因为我已经开启了,所以出现的是以上页面。
这样,邮箱的准备就已经完成了。
使用Django内置函数发邮件
1.在settings文件中加入以下配置
# 邮件设置
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.163.com'
EMAIL_PORT = 25
# 发送邮件的邮箱
EMAIL_HOST_USER = '发送邮件的邮箱'
# 在邮箱中设置的客户端授权密码
EMAIL_HOST_PASSWORD = '授权密码'
# 收件人看到的发件人
EMAIL_FROM = '绿色果园<发送邮件的邮箱>'
2.编写发送邮件代码
from django.shortcuts import render, redirect, HttpResponse
from django.core.mail import send_mail
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from django.conf import settings
def emailtest(request):
# 发送激活邮件,包括激活链接:http://127.0.0.1:8000/user/active/3
# 激活链接中需要包含用户的身份信息,并且要把身份信息进行加密
# 加密用户的身份信息,生成激活token
userid = 3
email = "接收邮件的邮箱账号"
serializer = Serializer(settings.SECRET_KEY, 1800)
info = {'confirm': userid}
token = serializer.dumps(info)
token = token.decode()
# 发邮件
subject = "绿色果园欢迎信息"
message = ""
sender = settings.EMAIL_FROM
receiver = [email]
html_message = "<h2>欢迎你成为绿色果园注册会员</h2></br>请点击以下链接激活账号<a href='http:127.0.0.1:8000/" \
"user/active/%s'>http:127.0.0.1:8000/user/active/%s</a>" % (token, token)
send_mail(subject, message, sender, receiver, html_message=html_message)
# 返回应答,跳转到首页
return HttpResponse("邮件发送成功,请注意接收")
配套url
urlpatterns = [
url(r'^emailtest/$', views.emailtest, name="emailtest"), # 发邮件测试
]
3.在浏览器中输入如下地址,即可看到“邮件已发送”的提示信息
http://127.0.0.1:8000/user/emailtest/
接收邮件如下图所示
收到邮件
邮件内容详情
使用celery发邮件
使用django内置的函数发送邮件时,django给stmp服务器发送邮件需要时间,stmp服务器发送邮件给用户也需要时间,而在发送邮件这段时间内,用户是在等服务端返回应答的,如果等待时间过长,那么无疑会大大的降低用户的体验。
这个时候,我们可以使用celery来异步发送邮件,即Django服务端在celery发送邮件的同时,返回应答给用户。这里,我们使用sleep来模拟发送邮件的时常。
1.安装celery
pip install celery
2.配置settings文件
# 邮件设置
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.163.com'
EMAIL_PORT = 25
# 发送邮件的邮箱
EMAIL_HOST_USER = '发送邮件的邮箱'
# 在邮箱中设置的客户端授权密码
EMAIL_HOST_PASSWORD = '客户端授权密码'
# 收件人看到的发件人
EMAIL_FROM = '绿色果园<发送邮件的邮箱>'
# diango的缓存配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/9",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
3.在项目下新建celery_tasks文件夹,在文件夹中新建tasks文件, 编写tasks文件 ;
from django.core.mail import send_mail
from django.conf import settings
from celery import Celery
import time
# 在任务处理者一端时需要加这几句
# import os
# import django
# os.environ.setdefault("DJANGO_SETTINGS_MODULE", "项目名.settings")
# django.setup()
# 创建一个Celery类的实例对象
app = Celery('celery_tasks.tasks', broker='redis://127.0.0.1:6379/8')
# 定义任务函数
@app.task
def send_register_active_email(to_email, username, token):
"""发送激活邮件"""
subject = "绿色果园欢迎信息"
message = ""
sender = settings.EMAIL_FROM
receiver = [to_email]
html_message = "<h2>%s, 欢迎你成为绿色果园注册会员</h2></br>请点击以下链接激活账号<a href='http:127.0.0.1:8000/" \
"user/active/%s'>http:127.0.0.1:8000/user/active/%s</a>" % (username, token, token)
send_mail(subject, message, sender, receiver, html_message=html_message)
time.sleep(5)
4.在发送邮件的地方 调用 celery_tasks下的tasks下的 发送邮件函数 ;
from django.shortcuts import render, redirect, HttpResponse
from django.core.mail import send_mail
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from django.conf import settings
def emailtest(request):
# 发送激活邮件,包括激活链接:http://127.0.0.1:8000/user/active/3
# 激活链接中需要包含用户的身份信息,并且要把身份信息进行加密
# 加密用户的身份信息,生成激活token
userid = 3
username = "mumun"
email = "收邮件的邮箱"
serializer = Serializer(settings.SECRET_KEY, 1800)
info = {'confirm': userid}
token = serializer.dumps(info)
token = token.decode()
# 使用celery发送邮件
send_register_active_email.delay(email, username, token)
# 返回应答,跳转到首页
return HttpResponse("邮件发送成功,请注意接收")
配套url
urlpatterns = [
url(r'^emailtest/$', views.emailtest, name="emailtest"), # 发邮件测试
]
5.开启redis服务;
E:\>cd E:\YifChanSoft\Database\Redis\RedisSoft\Redis-x64-3.2.100
E:\YifChanSoft\Database\Redis\RedisSoft\Redis-x64-3.2.100>redis-server --service-install redis.windows-service.conf --loglevel verbose
E:\YifChanSoft\Database\Redis\RedisSoft\Redis-x64-3.2.100>redis-cli
127.0.0.1:6379> select 8
OK
127.0.0.1:6379[8]> keys *
(empty list or set)
127.0.0.1:6379[8]> keys *
1) "_kombu.binding.celery"
2) "_kombu.binding.celery.pidbox"
3) "_kombu.binding.celeryev"
开启redis服务截图
6.将项目代码拷贝一份放在某处,进入该处, 启动tasks的worker模式 ,
注意,用作worker的代码的tasks文件中应该有提前启动django的初始化的代码,不然worker没法调用conf信息;
即应该有以下内容
# 在任务处理者一端时需要加这几句
import os
import django
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "项目名.settings")
django.setup()
开启worker模式:
celery -A celery_tasks.tasks worker -l info
出现问题,报错如下
ValueError: not enough values to unpack (expected 3, got 0)
原因
win10上运行celery4.x就会出现这个问题
解决
pip install eventlet
并在开启worker模式时加入参数
celery -A celery_tasks.tasks worker -l info -P eventlet
开启worker模式截图,后面还有内容,但因为太多了,就只截一半
7.在浏览器中输入如下地址,即可看到“邮件已发送”的提示信息
http://127.0.0.1:8000/user/emailtest/
接收邮件如下
来源:https://www.cnblogs.com/yifchan/p/python-1-34.html
猜你喜欢
- 我就废话不多说了,还是直接看代码吧!#!/usr/bin/env python3#coding = utf-8def is_triangle
- springboot配置文件抽离,便于服务器读取对应配置文件,避免项目频繁更改配置文件,影响项目的调试与发布1.创建统一配置中心项目coni
- pygame介绍Python Pygame 是一款专门为开发和设计 2D 电子游戏而生的软件包,它支 Windows、Linux、Mac O
- 导语还记得那些年,我们玩过的Windows小游戏吗?说起Windows自带的游戏,相信许多80、90后的朋友都不陌生。在很早的那个游戏贫瘠的
- 1.查看Anaconda中有哪些虚拟环境及所在目录:在桌面搜索框中输入Anaconda Prompt并打开输入命令conda env lis
- 需求细化:1.身份证必须能够通过身份证校验程序。2.通过查询,发现身份证号码是有国家标准的,标准号为 GB 11643-1999 可以从百度
- 几个利用背景结合a:hover做的小东东,希望对大家有所帮助。<!DOCTYPE html PUBLIC "-//W3C//
- Oracle是世界上用得最多的数据库之一,活动服务器网页(ASP)是一种被广泛用于创建 * 页的功能强大的服务器端脚本语言。许多ASP开发人
- 效果展示打地鼠小游戏简介打地鼠的游戏规则相信大家都知道,这里就不多介绍了,反正就是不停地拿锤子打洞里钻出来的地鼠呗~首先,让我们确定一下游戏
- (一)深入浅出理解索引结构实际上,您可以把索引理解为一种特殊的目录。微软的SQL SERVER提供了两种索引:聚集索引(clustered
- 最近几个不错网站被封,让人感觉很不爽,现在既不方便用,也不方便学习参考。正好想到曾经“截图”的事情,其实我认为互联网产品还有个特点,更新换代
- 首先看一下来自Wolfram的定义 马尔可夫链是随机变量{X_t}的集合(t贯穿0,1,..
- 本代码来源于 《Python和Pygame游戏开发指南》中的 Star Pusher 游戏,供大家参考,具体内容如下# Star Pushe
- 看到这个先思考,自己怎么输出他?为什么它有颜色?特殊符号去哪找?特殊符号在符号大全找 符号大全http://www.fhdq.net/任务1
- 前段时间由于收集视频数据的需要,自己捣鼓了一个YouKu视频批量下载的程序。东西虽然简单,但还挺实用的,拿出来分享给大家。版本:Python
- 一、装饰器的本质:装饰器(decorator)本质是函数闭包(function closure)的语法糖(Syntactic sugar)函
- python数据结构之 列表和元组序列:序列是一种数据结构,它包含的元素都进行了编号(从0开始)。典型的序列包括列表、字符串和元组。其中,列
- Microsoft SQL Server 2008通过与Microsoft Office的深度集成,为所有人提供了可用的商业智能,以合适的价
- 文章主要讲术了一些SQL Server新的Bug,帮您认识这些被忽略的SQL Server注入技巧。1.关于Openrowset和Opend
- 一、Python下载1.进入Python官网:https://www.python.org/2.选择windows版本(Download &