使用Celery完成發送短信


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"})


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM