您当前的位置:周俊奇博客 > 项目

Springboot使用QQ邮箱进行一个验证登入功能

时间:2022-10-17 11:33:43

这篇文章主要介绍了Spring boot 使用QQ邮箱进行一个验证登入,主要包括qq邮箱开启权限和创建发送验证码的请求Controller,本文通过示例代码给大家介绍的非常详细,需要的朋友可以参考下!

Spring boot 使用QQ邮箱进行一个验证登入

QQ邮箱开启权限

在QQ邮箱设置->账户里面,往下拉找到这个开启,手机号验证成功后会有一串英文字符串是待会儿要用到的密码。

c27884c368f020099af8db3edd5d0a71_2022101609221112.png

prom.xml 添加依赖

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-mail</artifactId>
</dependency>

在application.yml配置文件中对邮箱进行一个配置

spring:
  datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/community?useUnicode=true&characterEncoding=utf8&useSSL=false
username: root
password: 123456
  mail:
host: smtp.qq.com
username: 自己的qq@qq.com
password: 刚刚QQ邮箱那生成的那个字符串,不是邮箱密码
default-encoding: UTF-8
thymeleaf:
cache: false

创建发送验证码的请求Controller

使用session存放验证码。后面通过获取得到进行一个验证

package com.example.community.controller;

import lombok.extern.slf4j.Slf4j;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;
import javax.servlet.http.HttpSession;

@Slf4j
@RestController()
@RequestMapping("/mail")
@CrossOrigin(origins = {"http://localhost:8090", "null"})
public class MailController {
final String from="527734202@qq.com";
@Resource
JavaMailSender javaMailSender;
@GetMapping("/sendMail")
public void sendMail(String email , HttpSession session){
MimeMessage mimeMessage = javaMailSender.createMimeMessage();
try {
MimeMessageHelper mimeMessageHelper = new MimeMessageHelper(mimeMessage, true);
//设置发件人
mimeMessageHelper.setFrom(from);
//设置收件人
mimeMessageHelper.setTo(email);
//设置邮件主题
mimeMessageHelper.setSubject("信息管理验证");
//生成随机数
String random = randomInteger();
//将随机数放置到session中
session.setAttribute("email",email);
session.setAttribute("code",random);

//设置验证码的样式
mimeMessageHelper.setText("<font style='color:green'>"+random+"</font>",true);

javaMailSender.send(mimeMessage);

} catch (MessagingException e) {
e.printStackTrace();
}
}
//生成随机数
public String randomInteger(){
String random = "";
for (int i = 0; i < 6; i++) {
random += (int)(Math.random()*10);
}
return random.toString();
}
}

前端通过发送GET请求获取验证码,后台发送给用户邮箱。

注意代码中的细节,一定要使用@Resource注解,不然就会报错。

注册,登录验证

如果验证码正确,允许用户进行登入和注册。部分代码样例。

@PostMapping("/register")
public R register(@RequestBody User user, HttpSession session) {
String code1 = (String) session.getAttribute("code");
String email1 = (String) session.getAttribute("email");
if (!email1.equals(user.getEmail())) {
return R.error("邮箱错误");
}
if (!code1.equals(user.getCode())) {
return R.error("验证码错误");
}
User user1 = new User(user.getEmail(), user.getPassword());
return service.register(user1);
}

是不是很简单

标签: Springboot