栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

步骤
    • 一、开通腾讯云短信服务
    • 二、申请签名前的准备(申请公众号)
    • 三、创建签名和模板
    • 四、腾讯云API实现发送短信
    • 五、使用springboot进行调用
    • 六、可能会报的错误

一、开通腾讯云短信服务

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

二、申请签名前的准备(申请公众号)

三、创建签名和模板

1、创建签名

2、填写信息,然后确定,等审核

3、创建模板

4、填写信息,等待审核

一般来说模板还是比较容易成功的,一般来说是签名难通过点。

四、腾讯云API实现发送短信

1、腾讯云在线测试
在线测试地址:腾讯云api测试

在 短信控制台 添加应用后生成的实际 SdkAppId

填写测试api的参数

点击右边在线调用

发送请求

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



复制下来,后面要使用!

五、使用springboot进行调用

我们可以直接在上面测试那里生成代码,然后复制到springboot进行使用,也可以参照官方文档进行操作。
API文档链接地址:API文档
1、导入依赖




    com.tencentcloudapi
    tencentcloud-sdk-java
    3.1.423

注意:不要使用4.0.X版本,不是最新的
2、编写application.properties配置

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

3、创建工具类

@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

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));
   }

}

4、编写发送短信API
controller

@Api(tags = {"短信发送"})
@RestController
@RequestMapping("/edusms/sms")
@CrossOrigin
public class SmsController {
    @Autowired
    private SmsService smsService;

    @ApiOperation(value = "发送短信的方法")
    @GetMapping("send/{phone}")
    public R sendSms(
            @ApiParam(name = "phone",value = "手机号码",required = true)
            @PathVariable String phone
    ){
        //调用service发送短信的方法
        boolean isSend = smsService.send(phone);
        if (isSend){
           return R.ok();
        }else {
            return R.error().message("短信发送失败!");
        }
    }
}

serviceImpl

    //发送短信的方法
    @Override
    public boolean send(String phone) {
        //判断手机号是否为空
        if (StringUtils.isEmpty(phone)){
            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
            
//            String sessionContext = "xxx";
//            req.setSessionContext(sessionContext);

            //设置发送相关的参数
            String[] phoneNumberSet1 = {"+86"+phone};
            req.setPhoneNumberSet(phoneNumberSet1);//发送的手机号
            //生成6位数随机验证码
            String verificationCode = RandomUtil.getSixBitRandom();
            String[] templateParamSet1 = {verificationCode, "5"};//模板的参数 第一个是验证码,第二个是过期时间
            req.setTemplateParamSet(templateParamSet1);//发送验证码

            //发送短信
            // 返回的resp是一个SendSmsResponse的实例,与请求对象对应
            SendSmsResponse resp = client.SendSms(req);
            System.out.println("resp"+resp);
            // 输出json格式的字符串回包
            System.out.println(SendSmsResponse.toJsonString(resp));
            return true;
        } catch (TencentCloudSDKException e) {
            e.printStackTrace();
            return false;
        }
    }
}

5、使用swagger测试接口

六、可能会报的错误

Spring Boot读取application.properties可能会中文乱码
解决方法:idea设置编码格式

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/685005.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号