加入pom依赖
<!-- 邮件服务 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>
<!-- Thymeleaf 模版,用于发送模版邮件 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-email</artifactId>
<version>1.4</version>
</dependency>
<!-- 将数据转为json对象 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.76</version>
</dependency>
生成发送邮件的类
@RestController
@Slf4j
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
/**
* 发送邮箱验证码
*
* @param
* @return
*/
@PostMapping("/sendMsg")
public R<Map> sendMsg(@RequestBody Map map, HttpSession session) {
// 获取邮箱账号
String phone = (String) map.get("phone");
String subject = "MR.DC测试登录验证码";
if (StringUtils.isNotEmpty(phone)) {
String code = ValidateCodeUtils.generateValidateCode(4).toString();
String context = "祝你身体健康啊,欢迎使用session验证服务,登录验证码为: " + code + ",五分钟内有效,请妥善保管!";
log.info("code={}", code);
// 真正地发送邮箱验证码
userService.sendMsg(phone, subject, context);
// 将随机生成的验证码保存到session中
session.setAttribute(phone, code);
// 验证码由保存到session 优化为 缓存到Redis中,并且设置验证码的有效时间为 5分钟
// redisTemplate.opsForValue().set(phone, code, 5, TimeUnit.MINUTES);
return R.success(map);
}
return R.error("验证码发送失败,请重新输入!");
}
@PostMapping("/login")
public R<User>login(HttpSession session, @RequestBody Map map){
log.info("用户登录中");
String phone = map.get("phone").toString();
String code=map.get("code").toString();
Object attribute = session.getAttribute(phone);
if(attribute!=null&&attribute.equals(code)){
// 登录成功
log.info("登录成功,这是最后的斗争");
LambdaQueryWrapper<User> userLambdaQueryWrapper = new LambdaQueryWrapper<>();
userLambdaQueryWrapper.eq(User::getPhone,phone);
User user = userService.getOne(userLambdaQueryWrapper);
if(user==null){
user = new User();
user.setPhone(phone);
user.setStatus(1);
userService.save(user);
}
session.setAttribute("user",user.getId());
return R.success(user);
}
return R.error("登录失败");
}
}
发送邮件的服务实现类
@Slf4j
@Service
public class UserServiceImpl extends ServiceImpl<UserServiceMapper, User> implements UserService {
@Value("${spring.mail.username}")
private String from; // 邮件发送人
@Autowired
private JavaMailSender mailSender;
@Override
public void sendMsg(String to, String subject, String context) {
SimpleMailMessage mailMessage = new SimpleMailMessage();
mailMessage.setFrom(from);
mailMessage.setTo(to);
mailMessage.setSubject(subject);
mailMessage.setText(context);
// 真正的发送邮件操作,从 from到 to
mailSender.send(mailMessage);
log.info("发送邮件成功");
}
}
properties.yaml
mail:
# 如果25端口可用,则上面的配置就够用了。但是一般情况下25端口会被禁用,建议开启并使用465端口,走邮件的SSL协议
# 加入下面配置
host: smtp.qq.com # 发送邮件的服务器地址
username: # 开启 IMAP/SMTP服务 的qq邮箱的账号
password: # 开启 IMAP/SMTP服务 获得的授权码,而不是qq邮箱的登录密码
default-encoding: UTF-8
port: 465
protocol: smtps
validatecodeutills
public class ValidateCodeUtils {
/**
* 随机生成验证码
* @param length 长度为4位或者6位
* @return
*/
public static Integer generateValidateCode(int length){
Integer code =null;
if(length == 4){
code = new Random().nextInt(9999);//生成随机数,最大为9999
if(code < 1000){
code = code + 1000;//保证随机数为4位数字
}
}else if(length == 6){
code = new Random().nextInt(999999);//生成随机数,最大为999999
if(code < 100000){
code = code + 100000;//保证随机数为6位数字
}
}else{
throw new RuntimeException("只能生成4位或6位数字验证码");
}
return code;
}
/**
* 随机生成指定长度字符串验证码
* @param length 长度
* @return
*/
public static String generateValidateCode4String(int length){
Random rdm = new Random();
String hash1 = Integer.toHexString(rdm.nextInt());
String capstr = hash1.substring(0, length);
return capstr;
}
}