使用腾讯云发送短信API接口实现(完整流程)

Posted 零

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用腾讯云发送短信API接口实现(完整流程)相关的知识,希望对你有一定的参考价值。

一、开通腾讯云短信服务

在腾讯云官网找到短信服务,开通

 二、创建签名和模板

创建签名

填写信息,等待审核 

 

 创建模板

填写信息,等待审核 

 获取秘钥
官网链接:api秘钥

三、使用springboot进行调用

1.导入依赖

<!--腾讯云短信依赖-->
<!-- https://mvnrepository.com/artifact/com.tencentcloudapi/tencentcloud-sdk-java -->
<dependency>
    <groupId>com.tencentcloudapi</groupId>
    <artifactId>tencentcloud-sdk-java</artifactId>
    <version>3.1.423</version>
</dependency>

2、编写application.yml配置

tencent:
  sms:
    #腾讯云短信服务参数
    #腾讯云账户secretId,secretKey
    keyId: 
    keysecret: 
    #短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名
    signName: 
    #短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId
    smsSdkAppId: 
    #模板 ID: 必须填写已审核通过的模板 ID
    templateId: 

3、创建工具类

import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class ConstantSmsUtils implements InitializingBean 

    @Value("$tencent.sms.keyId")
    private String secretID ;
    @Value("$tencent.sms.keysecret")
    private String secretKey ;
    @Value("$tencent.sms.smsSdkAppId")
    private String smsSdkAppID ;
    @Value("$tencent.sms.signName")
    private String signName ;
    @Value("$tencent.sms.templateId")
    private String templateID ;

    public static String SECRET_ID;
    public static String SECRET_KEY;
    public static String SMSSDKAPP_ID;
    public static String SIGN_NAME;
    public static String TEMPLATE_ID;


    @Override
    public void afterPropertiesSet() throws Exception 
        SECRET_ID = secretID;
        SECRET_KEY = secretKey;
        SMSSDKAPP_ID = smsSdkAppID;
        SIGN_NAME = signName;
        TEMPLATE_ID = templateID;
    

生成随机数字的utils

import java.text.DecimalFormat;
import java.util.Random;

public class RandomUtil 

    private static final Random random = new Random();

    private static final DecimalFormat fourdf = new DecimalFormat("0000");

    private static final DecimalFormat sixdf = new DecimalFormat("000000");

    //生成4位随机数
    public static String getFourBitRandom() 
        return fourdf.format(random.nextInt(10000));
    
    //生成6位随机数
    public static String getSixBitRandom() 
        return sixdf.format(random.nextInt(1000000));
    

编写发送短信API

controller

    /**
     * 发送验证码
     * @param phoneNumber
     * @return
     */
    @ApiOperation("发送验证码")
    @PostMapping("/sendCode")
    public R sendCode(String phoneNumber) 
        boolean isSend = userService.send(phoneNumber);
        if (isSend)
            return R.ok();
        else 
            return R.fail("短信发送失败!");
        
    

serviceImpl

    /**
     * 发送验证码
     * @param phoneNumber
     * @return
     */
    @Override
    public boolean send(String phoneNumber) 
        //判断手机号是否为空
        if (StringUtils.isEmpty(phoneNumber))
            return false;
        
        try
            // 实例化一个认证对象,入参需要传入腾讯云账户secretId,secretKey,此处还需注意密钥对的保密
            // 密钥可前往https://console.cloud.tencent.com/cam/capi网站进行获取
            Credential cred = new Credential(ConstantSmsUtils.SECRET_ID, ConstantSmsUtils.SECRET_KEY);
            // 实例化一个http选项,可选的,没有特殊需求可以跳过
            HttpProfile httpProfile = new HttpProfile();
            httpProfile.setEndpoint("sms.tencentcloudapi.com");
            // 实例化一个client选项,可选的,没有特殊需求可以跳过
            ClientProfile clientProfile = new ClientProfile();
            clientProfile.setHttpProfile(httpProfile);
            // 实例化要请求产品的client对象,clientProfile是可选的  第二个参数是地域信息
            SmsClient client = new SmsClient(cred, "ap-guangzhou", clientProfile);
            // 实例化一个请求对象,每个接口都会对应一个request对象
            SendSmsRequest req = new SendSmsRequest();
            //设置固定的参数
            req.setSmsSdkAppId(ConstantSmsUtils.SMSSDKAPP_ID);// 短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId
            req.setSignName(ConstantSmsUtils.SIGN_NAME);//短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名
            req.setTemplateId(ConstantSmsUtils.TEMPLATE_ID);//模板 ID: 必须填写已审核通过的模板 ID
            /* 用户的 session 内容: 可以携带用户侧 ID 等上下文信息,server 会原样返回 */
//            String sessionContext = "xxx";
//            req.setSessionContext(sessionContext);

            //设置发送相关的参数
            String[] phoneNumberSet1 = "+86"+phoneNumber;
            req.setPhoneNumberSet(phoneNumberSet1);//发送的手机号
            //生成6位数随机验证码
            String verificationCode = RandomUtil.getSixBitRandom();
            String[] templateParamSet1 = verificationCode;//模板的参数 第一个是验证码,第二个是过期时间
            req.setTemplateParamSet(templateParamSet1);//发送验证码
            //发送短信
            // 返回的resp是一个SendSmsResponse的实例,与请求对象对应
            SendSmsResponse resp = client.SendSms(req);
            System.out.println("resp"+resp);
            // 输出json格式的字符串回包
            System.out.println(SendSmsResponse.toJsonString(resp));
            //将验证码放入redis中
//            redisService.setCacheObject(VERIFICATION_CODE + phoneNumber, verificationCode, 60*5L, TimeUnit.SECONDS);
            return true;
         catch (TencentCloudSDKException e) 
            e.printStackTrace();
            return false;
        
    
import com.tencentcloudapi.sms.v20210111.SmsClient;
import com.tencentcloudapi.sms.v20210111.models.SendSmsRequest;
import com.tencentcloudapi.sms.v20210111.models.SendSmsResponse;
#导包时这几个包一定要相对应

postman测试


    "code": 200,
    "msg": null,
    "data": null
#输出json格式的字符串回包

	"SendStatusSet":[
						
							"SerialNo":"2433:325730845216576992445817097",
							"PhoneNumber":"+8613888888888",
							"Fee":1,
							"SessionContext":"",
							"Code":"Ok",
							"Message":"send success",
							"IsoCode":"CN"
						
					],
	"RequestId":"2ee712e7-481d-460c-b6b3-e2857ba12086"

以上是关于使用腾讯云发送短信API接口实现(完整流程)的主要内容,如果未能解决你的问题,请参考以下文章

Python调用腾讯API发送短信验证码

腾讯云的短信接口买过了哪里有接口口文档

如何接入腾讯云短信接口

腾讯云短息验证码接口

JavaWeb-SpringBoot_一个类实现腾讯云SDK发送短信

接入腾讯云短信服务(史上最详细+该短信服务如何申请成功+发送短信验证码API讲解+相关错误分析)