需求
发送验证码短信然后接收验证码再完成注册

具体操作
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;










