python3 + django2.0 集成 「阿里雲通訊」 服務:html
(SDK文檔地址:https://help.aliyun.com/document_detail/55491.html?spm=5176.10629532.106.3.2fe01cbeAp0iFO)python
步驟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成功了,那麼在非虛擬環境中在安裝一次