celery是什么
Celery介绍:
- 一个简单、灵活且可靠、处理大量消息的分布式系统,可以在一台或者多台机器上运行。
- 单个 Celery 进程每分钟可处理数以百万计的任务。
- 通过消息进行通信,使用消息队列(broker)在客户端和消费者之间进行协调
----在需要同时处理多个任务得时候选择celery--------
celery的操作步骤
- 下载celery:pip install -U Celery
- 在项目中创建celery_tasks包实现celery功能
- 创建main方法作为celery入口
- 在mian入口中,新建celery实例对象
from celery import Celery
celery_app = Celery('meiduo')
- 建立配置文件,即消息队列,新建config的py文件,使用redis数据库进行中间人,
broker_url = 'redis://127.0.0.1/10'
- 将配置文件导入main中
celery_app.config_from_object('celery_tasks.config')
- 新建具体任务,在celery_tasks包中新建你的任务包,在包中新建tasks任务py文件,设置edf方法即消费者需要执行的
- 在main中注册任务
celery_app.autodiscover_tasks(['celery_tasks.sms', 'celery_tasks.email'])
- 为celery使用django配置文件在main中进行设置
import os
if not os.getenv('DJANGO_SETTINGS_MODULE'):
os.environ['DJANGO_SETTINGS_MODULE'] = 'meiduo_mall.settings.dev'
- 运行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,前端发送验证邮箱按钮变为已验证