需求

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

lua 验证码 验证码获_验证码

具体操作

1>点击"获取验证码"的按钮,会发送sendVerifyCode的异步请求并带上参数phone(number)

lua 验证码 验证码获_短信接口_02

lua 验证码 验证码获_验证码_03

查看前端代码html

lua 验证码 验证码获_验证码_04

查看对应的js代码

lua 验证码 验证码获_java_05

lua 验证码 验证码获_java_06

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>真实短信接口的实现

可以去网站去找第三方短信接口来实现,这里以京东万象的短信接口为例

 

lua 验证码 验证码获_短信接口_07

 依据请求实例的提醒去获取关键信息 appkey和url

lua 验证码 验证码获_java_08

问题来了,如何在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;