腾讯云搜索短信业务
先创建应用
需要记录的两个参数,在调用接口时需要设置
然后还需要申请一个免费的订阅号(公众号个人申请有些许麻烦)微信公众平台
下一步是创建签名和模板,前者需要审核,后者则比较简单
注意,签名内容需要和你申请下来的订阅号名称一致(初始都是新注册公众号这个名字),否则会不通过,不要问我怎么知道的。
模板比较简单,里面不可以加敏感信息(防诈骗),不可以有【】,因为之前的签名内容将被包含在【】里一起发出。
下面进入代码时间:
引入maven依赖
<!--腾讯云短信服务SDK-->
<dependency>
<groupId>com.github.qcloudsms</groupId>
<artifactId>qcloudsms</artifactId>
<version>1.0.2</version>
</dependency>
实体类,存储配置信息,这里用了lombok,避免冗余代码
package com.qcby.shujia.demo.entity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.context.annotation.Bean;
/**
* @className: SMSParameter
* @description: TODO 类描述
* @author: whz
* @date: 2021/11/26
**/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class SMSParameter {
private int appId = *********;
private String appKey = "********************";
private int templateId = *******;
private String smsSign = "新注册公众号";
}
这些参数都见明知意,不做过多解释
然后定义一个生成随机码的工具类
package com.qcby.shujia.demo.util;
import java.security.SecureRandom;
import java.util.Random;
/**
* @className: VerCodeGenerateUtil
* @description: TODO 类描述
* @author: whz
* @date: 2021/11/26
**/
public class VerCodeGenerateUtil {
private static final String SYMBOLS = "0123456789";//ABCDEFGHIGKLMNOPQRSTUVWXYZ
private static final Random RANDOM = new SecureRandom();
// 生成 4 位数的随机数字
public static String generateVerCode() {
char[] numbers = new char[4];
for (int i = 0; i < numbers.length; i++) {
numbers[i] = SYMBOLS.charAt(RANDOM.nextInt(SYMBOLS.length()));
}
return new String(numbers);
}
}
技术含量不是很高,继续
controller层代码
package com.qcby.shujia.demo.controller;
import com.github.qcloudsms.SmsSingleSender;
import com.github.qcloudsms.SmsSingleSenderResult;
import com.qcby.shujia.demo.common.web.ResultData;
import com.qcby.shujia.demo.entity.SMSParameter;
import com.qcby.shujia.demo.entity.User;
import com.qcby.shujia.demo.entity.vo.UserVo;
import com.qcby.shujia.demo.service.UserService;
import com.qcby.shujia.demo.util.ContextUtil;
import com.qcby.shujia.demo.util.TokenUtil;
import com.qcby.shujia.demo.util.VerCodeGenerateUtil;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest;
import javax.xml.ws.http.HTTPException;
import java.io.IOException;
import java.util.List;
/**
* @className: LoginController
* @description: 登陆控制
* @author: whz
* @date: 2021/9/23
**/
@RestController
@Api(tags = {"login模块"})
@RequestMapping("/login")
public class LoginController {
@Autowired
private UserService userService;
private SMSParameter smsParameter;
@GetMapping
@ApiOperation("login验证接口")
public ResultData login(User user){
//登录判断
if(StringUtils.isEmpty(user.getUsername()) || StringUtils.isEmpty(user.getPassword())) {
return ResultData.error("账号或密码为空");
}
User userDb= userService.login(user);
if(userDb==null){
return ResultData.error("账号或密码错误");
}
//根据登录用户获取所有权限信息
List<String> authStrList=userService.getAuthStrListByUser((UserVo) userDb);
//服务器存入用户登录信息之前设置其访问权限
userDb.setAuthStrList(authStrList);
//登录成功
String token= TokenUtil.getToken(userDb);
userDb.setToken(token);
return ResultData.ok(userDb);
}
@GetMapping("sendText")
public void sendText(String phone) throws HTTPException, IOException, com.github.qcloudsms.httpclient.HTTPException {
// 生成 随机验证码
String ver = VerCodeGenerateUtil.generateVerCode();
// 这里对应你的短信模板,如果需要传递两个参数,那么字符串数组应该有两个值
String[] code = new String[]{ver};
smsParameter = new SMSParameter();
//获得 id 和 key
SmsSingleSender sender = new SmsSingleSender(this.smsParameter.getAppId(), this.smsParameter.getAppKey());
// SmsSingleSenderResult result = sender.sendWithParam("86", phone, smsParameter.getTemplateId(),
// code, smsParameter.getSmsSign(), "", "" );
//发送短信,86 指的是国内短信,第二个是模板的 id,第三个是传递的参数,第四个是签名内容,后面两个可以传递空
SmsSingleSenderResult result = sender.sendWithParam("86", phone, this.smsParameter.getTemplateId(),
code, this.smsParameter.getSmsSign(), "", "");
// 如果 result 的结果是 0,说明发送成功
if (result.result == 0) {
System.out.println(code[0]);
} else {// 如果结果不是 0,说明出错了,打印错误信息以帮助修改
System.out.println(result.errMsg);
}
}
}
和登录验证分开了,后期可以合并一下, @GetMapping(“sendText”)就是发送短信的接口
接下来可以用postman测试