- 一、开通腾讯云短信服务
- 二、申请签名前的准备(申请公众号)
- 三、创建签名和模板
- 四、腾讯云API实现发送短信
- 五、使用springboot进行调用
- 六、可能会报的错误
在腾讯云官网找到短信服务,开通
略
三、创建签名和模板1、创建签名
2、填写信息,然后确定,等审核
3、创建模板
4、填写信息,等待审核
一般来说模板还是比较容易成功的,一般来说是签名难通过点。
1、腾讯云在线测试
在线测试地址:腾讯云api测试
在 短信控制台 添加应用后生成的实际 SdkAppId
填写测试api的参数
点击右边在线调用
发送请求
成功
获取秘钥
官网链接:api秘钥
复制下来,后面要使用!
我们可以直接在上面测试那里生成代码,然后复制到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设置编码格式



