django之集成阿里雲通訊(發送手機短信驗證碼)

python3 + django2.0 集成 「阿里雲通訊」 服務:html

(SDK文檔地址:https://help.aliyun.com/document_detail/55491.html?spm=5176.10629532.106.3.2fe01cbeAp0iFOpython

步驟1:django

  在阿里雲 「短信服務」 中建立一個簽名json

步驟2:api

  在阿里雲 「短信服務」 中建立一個短信模板緩存

步驟3:  ide

 下載阿里雲 「短信服務」 SDK函數

步驟4:測試

  在虛擬工做環境中安裝SDK:優化

    1> 進入SDK根目錄

    2> 在虛擬環境中執行命令:python setup.py install(最好是在虛擬運行環境中和非運行環境中都安裝一下,忘記了)

步驟5:

  1> 在阿里雲 「短信服務」 中獲得:<ACCESS_KEY_ID> 與 <ACCESS_KEY_SECRET>

  2> 在const.py 文件中修改:<ACCESS_KEY_ID> 與 <ACCESS_KEY_SECRET>

步驟6:

  測試:

    1> 在 demo_sms_send.py 文件中修改 

if __name__ == '__main__':
    __business_id = uuid.uuid1()
    # print(__business_id)
    # ,\"product\":\"雲通訊\"}"
    # 修改params參數,留着code驗證碼就行
    params = "{\"code\":\"314655\"}"
    # params = u'{"name":"wqb","code":"12345678","address":"bz","phone":"13000000000"}'
# id:固定的,接收驗證碼的手機號,簽名名稱,模板名稱,驗證碼
    print(send_sms(__business_id, "<13203160317>", "<李靖軒>", "<SMS_141905211>", params))

 

    2> 運行SDK中的Dome:python demo_sms_send.py,運行成功就會收到短信

步驟7:

  使用SDK:

    1> 將阿里雲SDK中的 「aliyunsdkdysmsapi」 文件夾複製到 django 項目中

    2> 將阿里雲SDK中的 「demo_sms_send.py」 文件複製到 django 項目中(或者建立一個aliyunsm.py文件,將內容複製到這個文件中)

     對文件進行優化:

# -*- coding: utf-8 -*-
import json
import sys
from aliyunsdkdysmsapi.request.v20170525 import SendSmsRequest
from aliyunsdkdysmsapi.request.v20170525 import QuerySendDetailsRequest
from aliyunsdkcore.client import AcsClient
import uuid
from aliyunsdkcore.profile import region_provider
from aliyunsdkcore.http import method_type as MT
from aliyunsdkcore.http import format_type as FT
"""
短信業務調用接口示例,版本號:v20170525
Created on 2017-06-12
"""
ACCESS_KEY_ID = "本身的<ACCESS_KEY_ID>"
ACCESS_KEY_SECRET = "本身的<ACCESS_KEY_SECRET>"
# 注意:不要更改
REGION = "cn-hangzhou"
PRODUCT_NAME = "Dysmsapi"
DOMAIN = "dysmsapi.aliyuncs.com"
acs_client = AcsClient(ACCESS_KEY_ID, ACCESS_KEY_SECRET, REGION)
region_provider.add_endpoint(PRODUCT_NAME, REGION, DOMAIN)
# def send_sms(business_id, phone_numbers, sign_name, template_code, template_param=None):
def send_sms(phone_numbers, code): """ 發送短信接口,在須要使用的地方引用該模塊,而後調用該接口便可 :param phone_numbers:發送的手機號碼 :param sign_name: 應用名 :param template_code: 模板名稱 :param template_param: 模板變量參數 :return: """ # 將部分參數固定,在調用方法的時候更簡潔,由於這些參數通常不會改變 sign_name = '<xxxx>' # 應用名稱 template_code = '<xxxxx>' # 模板名稱 template_param = json.dumps({'code':code}) # 模板變量參數
business_id = uuid.uuid1() smsRequest = SendSmsRequest.SendSmsRequest() # 申請的短信模板編碼,必填 smsRequest.set_TemplateCode(template_code) # 短信模板變量參數 if template_param is not None: smsRequest.set_TemplateParam(template_param) # 設置業務請求流水號,必填。 smsRequest.set_OutId(business_id) # 短信簽名 smsRequest.set_SignName(sign_name) # 數據提交方式 # smsRequest.set_method(MT.POST) # 數據提交格式 # smsRequest.set_accept_format(FT.JSON) # 短信發送的號碼列表,必填。 smsRequest.set_PhoneNumbers(phone_numbers) # 調用短信發送接口,返回json smsResponse = acs_client.do_action_with_exception(smsRequest) # TODO 業務處理 return smsResponse ## 這是測試用的代碼 # if __name__ == '__main__': # __business_id = uuid.uuid1() # # print(__business_id) # # ,\"product\":\"雲通訊\"}" # params = "{\"code\":\"314655\"}" # # params = u'{"name":"wqb","code":"12345678","address":"bz","phone":"13000000000"}' # print(send_sms(__business_id, "13203160137", "李靖軒", "SMS_141905211", params))

 

    3> 使用:

from xx.xx import xx # 導入發信模塊

# 發送驗證碼 view.py中的一個請求函數
def sms_captcha(request):
    # GET方式獲取手機號碼,例如:/sms_captcha/?telephone=xxx
    telephone = request.GET.get('telephone')
    code = '123456' # 設置驗證碼
    # 發送短信驗證碼,返回發信結果:result
    result = aliyunsms.send_sms(telephone,code)
    # 將短信驗證碼存入緩存中
    cache.set(telephone, code, 5 * 60)
    return HttpResponse("OK")

 

  

 

遇到的問題:

  

  解決:環境安裝問題,若是在虛擬環境中安裝SDK成功了,那麼在非虛擬環境中在安裝一次

相關文章
相關標籤/搜索