ToB企服应用市场:ToB评测及商务社交产业平台

标题: 腾讯云发送短信 [打印本页]

作者: 写过一篇    时间: 2024-6-11 11:54
标题: 腾讯云发送短信
一 准备工作

申请腾讯云服务发送短信: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 安装
  1. pip install --upgrade tencentcloud-sdk-python
复制代码
示例代码:
  1. # -*- coding: utf-8 -*-
  2. from tencentcloud.common import credential
  3. from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
  4. # 导入对应产品模块的client models。
  5. from tencentcloud.sms.v20210111 import sms_client, models
  6. # 导入可选配置类
  7. from tencentcloud.common.profile.client_profile import ClientProfile
  8. from tencentcloud.common.profile.http_profile import HttpProfile
  9. try:
  10.     # 必要步骤:
  11.     # 实例化一个认证对象,入参需要传入腾讯云账户密钥对secretId,secretKey。
  12.     # 这里采用的是从环境变量读取的方式,需要在环境变量中先设置这两个值。
  13.     # 你也可以直接在代码中写死密钥对,但是小心不要将代码复制、上传或者分享给他人,
  14.     # 以免泄露密钥对危及你的财产安全。
  15.     # SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capi
  16.     cred = credential.Credential("secretId", "secretKey")
  17.     # cred = credential.Credential(
  18.     #     os.environ.get(""),
  19.     #     os.environ.get("")
  20.     # )
  21.     # 实例化一个http选项,可选的,没有特殊需求可以跳过。
  22.     httpProfile = HttpProfile()
  23.     # 如果需要指定proxy访问接口,可以按照如下方式初始化hp(无需要直接忽略)
  24.     # httpProfile = HttpProfile(proxy="http://用户名:密码@代理IP:代理端口")
  25.     httpProfile.reqMethod = "POST"  # post请求(默认为post请求)
  26.     httpProfile.reqTimeout = 30    # 请求超时时间,单位为秒(默认60秒)
  27.     httpProfile.endpoint = "sms.tencentcloudapi.com"  # 指定接入地域域名(默认就近接入)
  28.     # 非必要步骤:
  29.     # 实例化一个客户端配置对象,可以指定超时时间等配置
  30.     clientProfile = ClientProfile()
  31.     clientProfile.signMethod = "TC3-HMAC-SHA256"  # 指定签名算法
  32.     clientProfile.language = "en-US"
  33.     clientProfile.httpProfile = httpProfile
  34.     # 实例化要请求产品(以sms为例)的client对象
  35.     # 第二个参数是地域信息,可以直接填写字符串ap-guangzhou,支持的地域列表参考 https://cloud.tencent.com/document/api/382/52071#.E5.9C.B0.E5.9F.9F.E5.88.97.E8.A1.A8
  36.     client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)
  37.     # 实例化一个请求对象,根据调用的接口和实际情况,可以进一步设置请求参数
  38.     # 你可以直接查询SDK源码确定SendSmsRequest有哪些属性可以设置
  39.     # 属性可能是基本类型,也可能引用了另一个数据结构
  40.     # 推荐使用IDE进行开发,可以方便的跳转查阅各个接口和数据结构的文档说明
  41.     req = models.SendSmsRequest()
  42.     # 基本类型的设置:
  43.     # SDK采用的是指针风格指定参数,即使对于基本类型你也需要用指针来对参数赋值。
  44.     # SDK提供对基本类型的指针引用封装函数
  45.     # 帮助链接:
  46.     # 短信控制台: https://console.cloud.tencent.com/smsv2
  47.     # 腾讯云短信小助手: https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81
  48.     # 短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId,示例如1400006666
  49.     # 应用 ID 可前往 [短信控制台](https://console.cloud.tencent.com/smsv2/app-manage) 查看
  50.     req.SmsSdkAppId = "1400787878"
  51.     # 短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名
  52.     # 签名信息可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-sign) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-sign) 的签名管理查看
  53.     req.SignName = "腾讯云"
  54.     # 模板 ID: 必须填写已审核通过的模板 ID
  55.     # 模板 ID 可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-template) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-template) 的正文模板管理查看
  56.     req.TemplateId = "449739"
  57.     # 模板参数: 模板参数的个数需要与 TemplateId 对应模板的变量个数保持一致,,若无模板参数,则设置为空
  58.     req.TemplateParamSet = ["1234"]
  59.     # 下发手机号码,采用 E.164 标准,+[国家或地区码][手机号]
  60.     # 示例如:+8613711112222, 其中前面有一个+号 ,86为国家码,13711112222为手机号,最多不要超过200个手机号
  61.     req.PhoneNumberSet = ["+8613711112222"]
  62.     # 用户的 session 内容(无需要可忽略): 可以携带用户侧 ID 等上下文信息,server 会原样返回
  63.     req.SessionContext = ""
  64.     # 短信码号扩展号(无需要可忽略): 默认未开通,如需开通请联系 [腾讯云短信小助手]
  65.     req.ExtendCode = ""
  66.     # 国际/港澳台短信 senderid(无需要可忽略): 国内短信填空,默认未开通,如需开通请联系 [腾讯云短信小助手]
  67.     req.SenderId = ""
  68.     resp = client.SendSms(req)
  69.     # 输出json格式的字符串回包
  70.     print(resp.to_json_string(indent=2))
  71.     # 当出现以下错误码时,快速解决方案参考
  72.     # - [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)
  73.     # - [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)
  74.     # - [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)
  75.     # - [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)
  76.     # - 更多错误,可咨询[腾讯云助手](https://tccc.qcloud.com/web/im/index.html#/chat?webAppId=8fa15978f85cb41f7e2ea36920cb3ae1&title=Sms)
  77. except TencentCloudSDKException as err:
  78.     print(err)
复制代码
三 短信功能封装(发送随机验证码)

创建一个python_send_message包
settings.py
  1. import os
  2. # 在系统环境变量设置SECRET_ID 和 SECRET_KEY
  3. SECRET_ID = os.environ.get("SECRET_ID", None)
  4. SECRET_KEY = os.environ.get("SECRET_KEY", None)
  5. SMS_SDK_APPID = ""
  6. SIGN_NAME = ""
  7. TEMPLATE_ID = ""
复制代码
main.py
  1. from tencentcloud.common import credential
  2. from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
  3. from tencentcloud.sms.v20210111 import sms_client, models
  4. from tencentcloud.common.profile.client_profile import ClientProfile
  5. from tencentcloud.common.profile.http_profile import HttpProfile
  6. from . import settings
  7. import random
  8. import json
  9. def get_code(num=6):
  10.     code = ''
  11.     for _ in range(num):
  12.         code += str(random.randint(0, 9))
  13.     return code
  14. def send_msg(code, phone):
  15.     try:
  16.         cred = credential.Credential(settings.SECRET_ID, settings.SECRET_KEY)
  17.         httpProfile = HttpProfile()
  18.         httpProfile.reqMethod = "POST"
  19.         httpProfile.reqTimeout = 30
  20.         httpProfile.endpoint = "sms.tencentcloudapi.com"
  21.         clientProfile = ClientProfile()
  22.         clientProfile.signMethod = "TC3-HMAC-SHA256"
  23.         clientProfile.language = "en-US"
  24.         clientProfile.httpProfile = httpProfile
  25.         client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)
  26.         req = models.SendSmsRequest()
  27.         req.SmsSdkAppId = settings.SMS_SDK_APPID
  28.         req.SignName = settings.SIGN_NAME
  29.         req.TemplateId = settings.TEMPLATE_ID
  30.         req.TemplateParamSet = [f"{code}", ]
  31.         req.PhoneNumberSet = [f"+86{phone}"]
  32.         req.SessionContext = ""
  33.         req.ExtendCode = ""
  34.         req.SenderId = ""
  35.         resp = client.SendSms(req)
  36.         response_json = resp.to_json_string()
  37.         response = json.loads(response_json)
  38.         status_dict = response.get('SendStatusSet')[0]
  39.         return {'code':status_dict.get('Code'), 'msg':status_dict.get('Message')}
  40.     except TencentCloudSDKException as err:
  41.         return {'code':'101', 'msg':str(err)}
复制代码
_init_.py
  1. from .main import get_code, send_msg
复制代码
利用时只需要导入包即可。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4