首頁 > 軟體

Spring boot 使用QQ郵箱進行一個驗證登入功能

2022-10-18 14:01:36

Spring boot 使用QQ郵箱進行一個驗證登入

QQ郵箱開啟許可權

在QQ郵箱設定->賬戶裡面,往下拉找到這個開啟,手機號驗證成功後會有一串英文字串是待會兒要用到的密碼。

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);
}

是不是很簡單

到此這篇關於Spring boot 使用QQ郵箱進行一個驗證登入的文章就介紹到這了,更多相關Spring boot驗證登入內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com