黑马程序员技术交流社区
标题: 【郑州校区】Java之品优购课程讲义_day14(6) [打印本页]
作者: 谷粒姐姐 时间: 2018-10-17 09:32
标题: 【郑州校区】Java之品优购课程讲义_day14(6)
4.3 注册判断短信验证码4.3.1 实现思路点击页面上的”获取短信验证码”连接,向后端传递手机号。后端随机生成 6 位数字作为短信验证码,将其保存在 redis 中(手机号作为 KEY),并发送到短信网关。
用户注册时,后端根据手机号查询 redis 中的验证码与用户填写的验证码是否相同,如果不同则提示用户不能注册。
4.3.2 生成验证码
(1)修改 pinyougou-user-interface 工程 UserService.java ,增加方法
[AppleScript] 纯文本查看 复制代码
/**
*生成短信验证码
*@return
*/
public void createSmsCode(String phone);
(2)修改 pinyougou-user-service 工程的 UserServiceImpl.java
[AppleScript] 纯文本查看 复制代码
@Autowired
private RedisTemplate<String , Object> redisTemplate;
/**
* 生成短信验证码
*/
public void createSmsCode(String phone){
//生成 6 位随机数
String code = (long) (Math.random()*1000000)+"";
System.out.println("验证码:"+code);
//存入缓存redisTemplate.boundHashOps("smscode").put(phone, code);
//发送到 activeMQ ....
}
(3)在 pinyougou-common 添加工具类 PhoneFormatCheckUtils.java,用于验证手机号
(4)修改 pinyougou-user-web 的 UserController.java
[AppleScript] 纯文本查看 复制代码
/**
*发送短信验证码
*@param phone
*@return
*/ @RequestMapping("/sendCode")
public Result sendCode(String phone){
//判断手机号格式
if(!PhoneFormatCheckUtils.isPhoneLegal(phone)){ return new Result(false, "手机号格式不正确");
}
try {
userService.createSmsCode(phone);//生成验证码
return new Result(true, "验证码发送成功");
} catch (Exception e) { e.printStackTrace();
return new Result(true, "验证码发送失败");
}
}
(5) pinyougou-user-web 的 userService.js
[AppleScript] 纯文本查看 复制代码
//发送验证码
this.sendCode=function(phone){
return $http.get("../user/sendCode.do?phone="+phone);
}
(5) pinyougou-user-web 的 userController.js
[AppleScript] 纯文本查看 复制代码
//发送验证码
$scope.sendCode=function(){
if($scope.entity.phone==null){
alert("请输入手机号!");
return ;
}
userService.sendCode($scope.entity.phone).success(
function(response){ alert(response.message);
}
);
}
(7)修改页面 register.html
[AppleScript] 纯文本查看 复制代码
< a ng-click="sendCode()" >获取短信验证码</ a>
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) |
黑马程序员IT技术论坛 X3.2 |