需求
发送验证码短信然后接收验证码再完成注册
具体操作
1>点击"获取验证码"的按钮,会发送sendVerifyCode的异步请求并带上参数phone(number)
查看前端代码html
查看对应的js代码
2>后端接口的实现
接口接收请求,获取到手机号,生成验证码code,拼接出短信,并发送短信(模拟)
// 发送验证码操作
@GetMapping("/sendVerifyCode")
public JsonResult sendVerifyCode(String phone){
userInfoService.sendVerifyCode(phone);
return JsonResult.success();
}
3>实现类的业务逻辑
- 获取手机号码phone和创建验证码code
- 拼接短信,发送短信,并告诉在多少分钟内使用时效
- 返回短信发送提示(后端模拟)
- 真实短信接口(下步做)
- 判断成功还是失败
- 缓存验证码,设置缓存时效
@Override
public void sendVerifyCode(String phone) {
// 获取手机号码phone 和 创建验证码code
String code = UUID.randomUUID().toString()
.replaceAll("-", "").substring(0, 4);
// 拼接短信,发送短信 并告诉时效
StringBuilder builder = new StringBuilder(80);
builder.append("您注册的验证码是:").append(code).append(",请在")
.append(Consts.VERIFY_CODE_VAI_TIME).append("分钟之内使用!");
// 返回短信发送提示
System.out.println(builder.toString()); // 模拟发送
// 以phone为key code为value 缓存验证码 设置时效5分钟
userInfoRedisService.setVerifyCode(phone,code);
}
4>真实短信接口的实现
可以去网站去找第三方短信接口来实现,这里以京东万象的短信接口为例
依据请求实例的提醒去获取关键信息 appkey和url
问题来了,如何在java代码中发起http请求?
解答-->spring提供了一个工具类,RestTemplate 能发起http请求
完善以上代码
@Override
public void sendVerifyCode(String phone) {
// 获取手机号码phone 和 创建验证码code
String code = UUID.randomUUID().toString()
.replaceAll("-", "").substring(0, 4);
// 拼接短信,发送短信 并告诉时效
StringBuilder builder = new StringBuilder(80);
builder.append("您注册的验证码是:").append(code).append(",请在")
.append(Consts.VERIFY_CODE_VAI_TIME).append("分钟之内使用!");
// 返回短信发送提示
System.out.println(builder.toString()); // 模拟发送
// 如何在java代码中发起http请求 jdk---URLHttpConnection--http
String appkey = "97841c945f568728327fd6f6e5aa3076";
String url = "https://way.jd.com/chuangxin/dxjk?mobile={0}&content=【创信】你的验证码是:{1},3分钟内有效!&appkey={2}";
// spring提供了一个工具类-->RestTemplate -->发起http请求
RestTemplate template = new RestTemplate();
// 以phone为key code为value 缓存验证码 设置时效5分钟
userInfoRedisService.setVerifyCode(phone,code);
}
5>优化代码(解决硬编码问题)
可以借助xml配置文件去解决
在核心子项目的core.properties中将appkey和url数据填进去
有个注意的点,因为中文编码问题,最好去网上进行编码转换
sms.url=https://way.jd.com/chuangxin/dxjk?mobile={0}&content=【创信】你的验证码是:{1},3分钟内有效!&appkey={2}
sms.appkey=97841c945f568728327fd6f6e5aa3076
在实现类上
// 从配置获取信息 解决硬编码问题
@Value("${sms.appkey}")
private String appkey;
@Value("${sms.url}")
private String url;