♻️ Refactoring code. 发送验证码组件需要判断手机号是否存在用户列表中 #749

This commit is contained in:
lbw 2022-10-13 10:32:42 +08:00
parent 112375dd84
commit 23b18c43e0
4 changed files with 59 additions and 17 deletions

View File

@ -0,0 +1,27 @@
package com.pig4cloud.pig.admin.api.dto;
import lombok.Data;
import javax.validation.constraints.NotBlank;
/**
* 客户端请求验证码
*
* @author lengleng
* @date 2022/10/13
*/
@Data
public class AppSmsDTO {
/**
* 手机号
*/
@NotBlank(message = "手机号不能为空")
private String phone;
/**
* 手机号是否存在数据库
*/
private Boolean exist;
}

View File

@ -1,6 +1,7 @@
package com.pig4cloud.pig.admin.controller; package com.pig4cloud.pig.admin.controller;
import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.pig4cloud.pig.admin.api.dto.AppSmsDTO;
import com.pig4cloud.pig.admin.api.dto.UserInfo; import com.pig4cloud.pig.admin.api.dto.UserInfo;
import com.pig4cloud.pig.admin.api.entity.SysUser; import com.pig4cloud.pig.admin.api.entity.SysUser;
import com.pig4cloud.pig.admin.service.AppService; import com.pig4cloud.pig.admin.service.AppService;
@ -13,10 +14,9 @@ import io.swagger.v3.oas.annotations.security.SecurityRequirement;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import org.springframework.http.HttpHeaders; import org.springframework.http.HttpHeaders;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping; import javax.validation.Valid;
import org.springframework.web.bind.annotation.RestController;
/** /**
* @author lengleng * @author lengleng
@ -33,10 +33,15 @@ public class AppController {
private final SysUserService userService; private final SysUserService userService;
/**
* 发送手机验证码
* @param sms 请求手机对象
* @return code
*/
@Inner(value = false) @Inner(value = false)
@GetMapping("/{mobile}") @PostMapping("/sms")
public R<Boolean> sendSmsCode(@PathVariable String mobile) { public R<Boolean> sendSmsCode(@Valid @RequestBody AppSmsDTO sms) {
return appService.sendSmsCode(mobile); return appService.sendSmsCode(sms);
} }
/** /**

View File

@ -17,6 +17,7 @@
package com.pig4cloud.pig.admin.service; package com.pig4cloud.pig.admin.service;
import com.pig4cloud.pig.admin.api.dto.AppSmsDTO;
import com.pig4cloud.pig.common.core.util.R; import com.pig4cloud.pig.common.core.util.R;
/** /**
@ -27,10 +28,10 @@ public interface AppService {
/** /**
* 发送手机验证码 * 发送手机验证码
* @param phone phone * @param sms phone
* @return code * @return code
*/ */
R<Boolean> sendSmsCode(String phone); R<Boolean> sendSmsCode(AppSmsDTO sms);
/** /**
* 校验验证码 * 校验验证码

View File

@ -18,6 +18,9 @@
package com.pig4cloud.pig.admin.service.impl; package com.pig4cloud.pig.admin.service.impl;
import cn.hutool.core.util.RandomUtil; import cn.hutool.core.util.RandomUtil;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.pig4cloud.pig.admin.api.dto.AppSmsDTO;
import com.pig4cloud.pig.admin.api.entity.SysUser;
import com.pig4cloud.pig.admin.mapper.SysUserMapper; import com.pig4cloud.pig.admin.mapper.SysUserMapper;
import com.pig4cloud.pig.admin.service.AppService; import com.pig4cloud.pig.admin.service.AppService;
import com.pig4cloud.pig.common.core.constant.CacheConstants; import com.pig4cloud.pig.common.core.constant.CacheConstants;
@ -53,25 +56,31 @@ public class AppServiceImpl implements AppService {
/** /**
* 发送手机验证码 TODO: 调用短信网关发送验证码,测试返回前端 * 发送手机验证码 TODO: 调用短信网关发送验证码,测试返回前端
* @param phone 手机号 * @param sms 手机号
* @return code * @return code
*/ */
@Override @Override
public R<Boolean> sendSmsCode(String phone) { public R<Boolean> sendSmsCode(AppSmsDTO sms) {
Object codeObj = redisTemplate.opsForValue().get(CacheConstants.DEFAULT_CODE_KEY + phone); Object codeObj = redisTemplate.opsForValue().get(CacheConstants.DEFAULT_CODE_KEY + sms.getPhone());
if (codeObj != null) { if (codeObj != null) {
log.info("手机号验证码未过期:{}{}", phone, codeObj); log.info("手机号验证码未过期:{}{}", sms.getPhone(), codeObj);
return R.ok(Boolean.FALSE, MsgUtils.getMessage(ErrorCodes.SYS_APP_SMS_OFTEN)); return R.ok(Boolean.FALSE, MsgUtils.getMessage(ErrorCodes.SYS_APP_SMS_OFTEN));
} }
// 校验手机号是否存在 sys_user
if (sms.getExist()
&& !userMapper.exists(Wrappers.<SysUser>lambdaQuery().eq(SysUser::getPhone, sms.getPhone()))) {
return R.ok(Boolean.FALSE, MsgUtils.getMessage(ErrorCodes.SYS_APP_PHONE_UNREGISTERED, sms.getPhone()));
}
String code = RandomUtil.randomNumbers(Integer.parseInt(SecurityConstants.CODE_SIZE)); String code = RandomUtil.randomNumbers(Integer.parseInt(SecurityConstants.CODE_SIZE));
log.info("手机号生成验证码成功:{},{}", phone, code); log.info("手机号生成验证码成功:{},{}", sms.getPhone(), code);
redisTemplate.opsForValue().set(CacheConstants.DEFAULT_CODE_KEY + phone, code, SecurityConstants.CODE_TIME, redisTemplate.opsForValue().set(CacheConstants.DEFAULT_CODE_KEY + sms.getPhone(), code,
TimeUnit.SECONDS); SecurityConstants.CODE_TIME, TimeUnit.SECONDS);
// 调用短信通道发送 // 调用短信通道发送
this.smsClient.sendCode(code, phone); this.smsClient.sendCode(code, sms.getPhone());
return R.ok(Boolean.TRUE, code); return R.ok(Boolean.TRUE, code);
} }