在meiduo/meiduo_mall
下創建celery_tasks用於保存celery異步任務。
在celery_tasks目錄下創建config.py文件,用於保存celery的配置信息
broker_url = "redis://127.0.0.1/14"
在celery_tasks目錄下創建main.py文件,用於作為celery的啟動文件
from celery import Celery # 為celery使用django配置文件進行設置 import os if not os.getenv('DJANGO_SETTINGS_MODULE'): os.environ['DJANGO_SETTINGS_MODULE'] = 'meiduo_mall.settings.dev' # 創建celery應用 app = Celery('meiduo') # 導入celery配置 app.config_from_object('celery_tasks.config') # 自動注冊celery任務 app.autodiscover_tasks(['celery_tasks.sms'])
在celery_tasks目錄下創建sms目錄,用於放置發送短信的異步任務相關代碼。
將提供的發送短信的雲通訊SDK放到celery_tasks/sms/目錄下。
在celery_tasks/sms/目錄下創建tasks.py文件,用於保存發送短信的異步任務
import logging from celery_tasks.main import app from .yuntongxun.sms import CCP logger = logging.getLogger("django") # 驗證碼短信模板 SMS_CODE_TEMP_ID = 1 @app.task(name='send_sms_code') def send_sms_code(mobile, code, expires): """ 發送短信驗證碼 :param mobile: 手機號 :param code: 驗證碼 :param expires: 有效期 :return: None """ try: ccp = CCP() result = ccp.send_template_sms(mobile, [code, expires], SMS_CODE_TEMP_ID) except Exception as e: logger.error("發送驗證碼短信[異常][ mobile: %s, message: %s ]" % (mobile, e)) else: if result == 0: logger.info("發送驗證碼短信[正常][ mobile: %s ]" % mobile) else: logger.warning("發送驗證碼短信[失敗][ mobile: %s ]" % mobile)
在verifications/views.py中改寫SMSCodeView視圖,使用celery異步任務發送短信
from celery_tasks.sms import tasks as sms_tasks class SMSCodeView(GenericAPIView): ... # 發送短信驗證碼 sms_code_expires = str(constants.SMS_CODE_REDIS_EXPIRES // 60) sms_tasks.send_sms_code.delay(mobile, sms_code, sms_code_expires) return Response({"message": "OK"})