一 准备工作
申请腾讯云服务发送短信:https://console.cloud.tencent.com/smsv2
创建签名
创建正文模板
二 python发送短信
SDK文档:python:https://cloud.tencent.com/document/product/382/43196
获取安装:
安装 Python SDK 前,先获取安全凭证。在第一次利用云 API 之前,用户首先需要在 腾讯云控制台 上申致意全凭证,安全凭证包罗 SecretID 和 SecretKey, SecretID 是用于标识 API 调用者的身份,SecretKey 是用于加密签名字符串和服务器端验证签名字符串的密钥。SecretKey 必须严酷保管,制止泄露。
通过 Pip 安装
- pip install --upgrade tencentcloud-sdk-python
复制代码 示例代码:
- # -*- coding: utf-8 -*-
- from tencentcloud.common import credential
- from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
- # 导入对应产品模块的client models。
- from tencentcloud.sms.v20210111 import sms_client, models
- # 导入可选配置类
- from tencentcloud.common.profile.client_profile import ClientProfile
- from tencentcloud.common.profile.http_profile import HttpProfile
- try:
- # 必要步骤:
- # 实例化一个认证对象,入参需要传入腾讯云账户密钥对secretId,secretKey。
- # 这里采用的是从环境变量读取的方式,需要在环境变量中先设置这两个值。
- # 你也可以直接在代码中写死密钥对,但是小心不要将代码复制、上传或者分享给他人,
- # 以免泄露密钥对危及你的财产安全。
- # SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capi
- cred = credential.Credential("secretId", "secretKey")
- # cred = credential.Credential(
- # os.environ.get(""),
- # os.environ.get("")
- # )
- # 实例化一个http选项,可选的,没有特殊需求可以跳过。
- httpProfile = HttpProfile()
- # 如果需要指定proxy访问接口,可以按照如下方式初始化hp(无需要直接忽略)
- # httpProfile = HttpProfile(proxy="http://用户名:密码@代理IP:代理端口")
- httpProfile.reqMethod = "POST" # post请求(默认为post请求)
- httpProfile.reqTimeout = 30 # 请求超时时间,单位为秒(默认60秒)
- httpProfile.endpoint = "sms.tencentcloudapi.com" # 指定接入地域域名(默认就近接入)
- # 非必要步骤:
- # 实例化一个客户端配置对象,可以指定超时时间等配置
- clientProfile = ClientProfile()
- clientProfile.signMethod = "TC3-HMAC-SHA256" # 指定签名算法
- clientProfile.language = "en-US"
- clientProfile.httpProfile = httpProfile
- # 实例化要请求产品(以sms为例)的client对象
- # 第二个参数是地域信息,可以直接填写字符串ap-guangzhou,支持的地域列表参考 https://cloud.tencent.com/document/api/382/52071#.E5.9C.B0.E5.9F.9F.E5.88.97.E8.A1.A8
- client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)
- # 实例化一个请求对象,根据调用的接口和实际情况,可以进一步设置请求参数
- # 你可以直接查询SDK源码确定SendSmsRequest有哪些属性可以设置
- # 属性可能是基本类型,也可能引用了另一个数据结构
- # 推荐使用IDE进行开发,可以方便的跳转查阅各个接口和数据结构的文档说明
- req = models.SendSmsRequest()
- # 基本类型的设置:
- # SDK采用的是指针风格指定参数,即使对于基本类型你也需要用指针来对参数赋值。
- # SDK提供对基本类型的指针引用封装函数
- # 帮助链接:
- # 短信控制台: https://console.cloud.tencent.com/smsv2
- # 腾讯云短信小助手: https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81
- # 短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId,示例如1400006666
- # 应用 ID 可前往 [短信控制台](https://console.cloud.tencent.com/smsv2/app-manage) 查看
- req.SmsSdkAppId = "1400787878"
- # 短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名
- # 签名信息可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-sign) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-sign) 的签名管理查看
- req.SignName = "腾讯云"
- # 模板 ID: 必须填写已审核通过的模板 ID
- # 模板 ID 可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-template) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-template) 的正文模板管理查看
- req.TemplateId = "449739"
- # 模板参数: 模板参数的个数需要与 TemplateId 对应模板的变量个数保持一致,,若无模板参数,则设置为空
- req.TemplateParamSet = ["1234"]
- # 下发手机号码,采用 E.164 标准,+[国家或地区码][手机号]
- # 示例如:+8613711112222, 其中前面有一个+号 ,86为国家码,13711112222为手机号,最多不要超过200个手机号
- req.PhoneNumberSet = ["+8613711112222"]
- # 用户的 session 内容(无需要可忽略): 可以携带用户侧 ID 等上下文信息,server 会原样返回
- req.SessionContext = ""
- # 短信码号扩展号(无需要可忽略): 默认未开通,如需开通请联系 [腾讯云短信小助手]
- req.ExtendCode = ""
- # 国际/港澳台短信 senderid(无需要可忽略): 国内短信填空,默认未开通,如需开通请联系 [腾讯云短信小助手]
- req.SenderId = ""
- resp = client.SendSms(req)
- # 输出json格式的字符串回包
- print(resp.to_json_string(indent=2))
- # 当出现以下错误码时,快速解决方案参考
- # - [FailedOperation.SignatureIncorrectOrUnapproved](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Afailedoperation.signatureincorrectorunapproved-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
- # - [FailedOperation.TemplateIncorrectOrUnapproved](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Afailedoperation.templateincorrectorunapproved-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
- # - [UnauthorizedOperation.SmsSdkAppIdVerifyFail](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Aunauthorizedoperation.smssdkappidverifyfail-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
- # - [UnsupportedOperation.ContainDomesticAndInternationalPhoneNumber](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Aunsupportedoperation.containdomesticandinternationalphonenumber-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
- # - 更多错误,可咨询[腾讯云助手](https://tccc.qcloud.com/web/im/index.html#/chat?webAppId=8fa15978f85cb41f7e2ea36920cb3ae1&title=Sms)
- except TencentCloudSDKException as err:
- print(err)
复制代码 三 短信功能封装(发送随机验证码)
创建一个python_send_message包
settings.py
- import os
- # 在系统环境变量设置SECRET_ID 和 SECRET_KEY
- SECRET_ID = os.environ.get("SECRET_ID", None)
- SECRET_KEY = os.environ.get("SECRET_KEY", None)
- SMS_SDK_APPID = ""
- SIGN_NAME = ""
- TEMPLATE_ID = ""
复制代码 main.py
- from tencentcloud.common import credential
- from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
- from tencentcloud.sms.v20210111 import sms_client, models
- from tencentcloud.common.profile.client_profile import ClientProfile
- from tencentcloud.common.profile.http_profile import HttpProfile
- from . import settings
- import random
- import json
- def get_code(num=6):
- code = ''
- for _ in range(num):
- code += str(random.randint(0, 9))
- return code
- def send_msg(code, phone):
- try:
- cred = credential.Credential(settings.SECRET_ID, settings.SECRET_KEY)
- httpProfile = HttpProfile()
- httpProfile.reqMethod = "POST"
- httpProfile.reqTimeout = 30
- httpProfile.endpoint = "sms.tencentcloudapi.com"
- clientProfile = ClientProfile()
- clientProfile.signMethod = "TC3-HMAC-SHA256"
- clientProfile.language = "en-US"
- clientProfile.httpProfile = httpProfile
- client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)
- req = models.SendSmsRequest()
- req.SmsSdkAppId = settings.SMS_SDK_APPID
- req.SignName = settings.SIGN_NAME
- req.TemplateId = settings.TEMPLATE_ID
- req.TemplateParamSet = [f"{code}", ]
- req.PhoneNumberSet = [f"+86{phone}"]
- req.SessionContext = ""
- req.ExtendCode = ""
- req.SenderId = ""
- resp = client.SendSms(req)
- response_json = resp.to_json_string()
- response = json.loads(response_json)
- status_dict = response.get('SendStatusSet')[0]
- return {'code':status_dict.get('Code'), 'msg':status_dict.get('Message')}
- except TencentCloudSDKException as err:
- return {'code':'101', 'msg':str(err)}
复制代码 _init_.py
- from .main import get_code, send_msg
复制代码 利用时只需要导入包即可。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |