【瑞吉外賣】手機號驗證碼登錄(用QQ郵件發送代替)

目錄

介紹

一、獲取授權碼

二、前端代碼修改

三、后端代碼修改

①pom依賴

②yml配置

③控制層

④業務層

⑤工具類


介紹

本文介紹了QQ郵箱驗證碼登錄功能的實現步驟:

  1. 獲取QQ郵箱授權碼并配置;
  2. 前端修改登錄頁面,增加驗證碼發送接口調用和登錄邏輯;
  3. 后端實現包括:添加郵件依賴、配置郵件參數、開發驗證碼發送接口(使用隨機4位數字)、登錄驗證邏輯(自動注冊新用戶)、郵件發送服務等。

? ? ? ?重點使用了Spring Boot Mail組件實現郵件發送,通過Session存儲驗證碼進行校驗,并提供了完整的工具類生成隨機驗證碼。系統實現了基于手機號和郵箱驗證碼的登錄功能,包含自動注冊新用戶的能力。


一、獲取授權碼

QQ郵箱

生成授權碼如下,最好截圖保存,后續要用到


二、前端代碼修改

2.1 調用發送驗證碼API接口,并取消自動填充驗證碼。代碼位置:front/page/login.html

methods:{getCode(){this.form.code = ''// const regex = /^(13[0-9]{9})|(15[0-9]{9})|(17[0-9]{9})|(18[0-9]{9})|(19[0-9]{9})$/;// 修復后的正則表達式const regex = /^(13[0-9]{9}|15[0-9]{9}|17[0-9]{9}|18[0-9]{9}|19[0-9]{9})$/;    if (regex.test(this.form.phone)) {this.msgFlag = false// this.form.code = (Math.random()*1000000).toFixed(0)sendMsgApi({phone:this.form.phone})}else{this.msgFlag = true}},async btnLogin(){if(this.form.phone && this.form.code){this.loading = true// const res = await loginApi({phone:this.form.phone})const res = await loginApi({phone:this.form.phone,code:this.form.code})this.loading = falseif(res.code === 1){sessionStorage.setItem("userPhone",this.form.phone)window.requestAnimationFrame(()=>{window.location.href= '/front/index.html'})                           }else{this.$notify({ type:'warning', message:res.msg});}}else{this.$notify({ type:'warning', message:'請輸入手機號碼'});}}

2.2 增加一個發送驗證碼API。代碼位置:front/api/login.js

function loginApi(data) {return $axios({'url': '/employee/login','method': 'post',data})
}

三、后端代碼修改

①pom依賴

<!--mail短信依賴-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-mail</artifactId>
</dependency>

②yml配置

這里需要配置【郵箱】和剛剛獲取的【授權碼】

spring:mail:host: smtp.qq.com#發送驗證碼的郵箱username: xxxxxxxxxxx@qq.com# 你的QQ郵箱授權碼password: xxxxxxxxxxxssl:enabled: true

③控制層

@RestController
@RequestMapping("/user")
@Slf4j
public class UserController {@Autowiredprivate IUserService userService;//獲取驗證碼@PostMapping("/sendMsg")public R<String> sendMsg(HttpSession session, @RequestBody User user){//獲取郵箱號//相當于發送短信定義的String toString phone = user.getPhone();String subject = "瑞吉外賣";//StringUtils.isNotEmpty字符串非空判斷if (StringUtils.isNotEmpty(phone)) {//發送一個四位數的驗證碼,把驗證碼變成String類型String code = ValidateCodeUtils.generateValidateCode(4).toString();String text = "【瑞吉外賣】您好,您的登錄驗證碼為:" + code + ",請盡快登錄";log.info("驗證碼為:" + code);//發送短信userService.sendMsg(subject,text);//將驗證碼保存到session當中session.setAttribute(phone,code);return R.success("驗證碼發送成功");}return R.error("驗證碼發送異常,請重新發送");}//登錄@PostMapping("/login")//Map存JSON數據public R<User> login(HttpSession session,@RequestBody Map map){//獲取郵箱,用戶輸入的String phone = map.get("phone").toString();//獲取驗證碼,用戶輸入的String code = map.get("code").toString();//獲取session中保存的驗證碼Object sessionCode = session.getAttribute(phone);//如果session的驗證碼和用戶輸入的驗證碼進行比對,&&同時if (sessionCode != null && sessionCode.equals(code)) {//要是User數據庫沒有這個郵箱則自動注冊,先看看輸入的郵箱是否存在數據庫LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(User::getPhone,phone);//獲得唯一的用戶,因為手機號是唯一的User user = userService.getOne(queryWrapper);//要是User數據庫沒有這個郵箱則自動注冊if (user == null) {user = new User();user.setPhone(phone);user.setStatus(1);//取郵箱的前五位為用戶名user.setName(phone.substring(0,6));userService.save(user);}//不保存這個用戶名就登不上去,因為過濾器需要得到這個user才能放行,程序才知道你登錄了session.setAttribute("user", user.getId());return R.success(user);}return R.error("登錄失敗");}
}

④業務層

接口

public interface IUserService extends IService<User> {void sendMsg(String subject,String text);
}

實現類

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper,User> implements IUserService {//把yml配置的郵箱號賦值到from@Value("${spring.mail.username}")private String email;//發送郵件需要的對象@Autowiredprivate JavaMailSender javaMailSender;//郵件發送人@Overridepublic void sendMsg(String subject, String text) {//發送簡單郵件,簡單郵件不包括附件等別的SimpleMailMessage message = new SimpleMailMessage();message.setFrom(email);message.setTo(email);message.setSubject(subject);message.setText(text);//發送郵件javaMailSender.send(message);}
}

⑤工具類

ValidateCodeUtils.java,黑馬給了此代碼;不用 SMSUtils.java

package com.itheima.reggie.utils;import java.util.Random;/*** 隨機生成驗證碼工具類*/
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);//生成隨機數,最大為9999if(code < 1000){code = code + 1000;//保證隨機數為4位數字}}else if(length == 6){code = new Random().nextInt(999999);//生成隨機數,最大為999999if(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;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/97487.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/97487.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/97487.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

為什么要用 Markdown?以及如何使用它

在處理大量文檔時&#xff0c;尤其是在構建知識庫、進行文檔分析或訓練大語言模型&#xff08;LLM&#xff09;時&#xff0c;將各種格式的文件&#xff08;如 PDF、Word、Excel、PPT、HTML 等&#xff09;轉換為統一的 Markdown 格式&#xff0c;能夠顯著提高處理效率和兼容性…

訂餐后臺管理系統-day06菜品分類模塊

菜品分類顯示我們需要先實現分類操作&#xff0c;因為沒有菜品分類&#xff0c;我們無法準確知道當前菜品屬于哪個分類&#xff0c;在前端顯示時&#xff0c;需要根據分類顯示數據先顯示分類列表頁面準備路由manage_bp.route(/food/cat/list) def food_cat_list():# 默認頁面從…

More Effective C++ 條款20:協助完成返回值優化(Facilitate the Return Value Optimization)

More Effective C 條款20&#xff1a;協助完成返回值優化&#xff08;Facilitate the Return Value Optimization&#xff09;核心思想&#xff1a;返回值優化&#xff08;RVO&#xff09;是編譯器消除函數返回時臨時對象的一種重要優化技術。通過編寫適合RVO的代碼&#xff0c…

《HelloGitHub》第 113 期

興趣是最好的老師&#xff0c;HelloGitHub 讓你對開源感興趣&#xff01;簡介HelloGitHub 分享 GitHub 上有趣、入門級的開源項目。github.com/521xueweihan/HelloGitHub這里有實戰項目、入門教程、黑科技、開源書籍、大廠開源項目等&#xff0c;涵蓋多種編程語言 Python、Java…

萌寶喂養日志-我用AI做喂養記錄小程序1-原型設計

準備工作 首先&#xff0c;注冊硅基流動賬號&#xff0c;并配置Trae開發工具。 ↓現在注冊有2000 萬 Tokens 的免費額度↓。 硅基流動統一登錄 具體可以看我這篇文章&#xff1a;Trae接入自有Deepseek模型&#xff0c;不再排隊等待-CSDN博客 實踐 設計原型圖 我想開發一…

工業產品營銷:概念、原理、流程與實踐指南

摘要 工業產品營銷是針對B2B市場的專業化推廣活動,旨在滿足企業客戶的生產和運營需求。本文詳細闡述了工業產品營銷的概念與特點,分析其核心原理,包括客戶需求驅動、價值傳遞和關系管理。營銷過程涵蓋市場調研、細分定位、策略制定、執行、轉化及售后服務六個步驟,并提供品…

【讀書筆記】《人體微生物的奧秘》

Follow Your Gut&#xff1a;人體微生物的奧秘 引言&#xff1a;從蚊子到微生物 夏天來臨&#xff0c;許多人又開始糾結為什么有些人特別招蚊子。有人說是血型問題&#xff0c;有人說是皮膚嫩度&#xff0c;還有人歸結于基因。但今天要分享的一本書&#xff0c;雖然標題看似討論…

【Matplotlib學習】駕馭畫布:Matplotlib 布局方式從入門到精通完全指南

目錄駕馭畫布&#xff1a;Matplotlib 布局方式從入門到精通完全指南一、 核心理念&#xff1a;理解 Figure 和 Axes二、 布局方式大全&#xff1a;從簡單到復雜類別一&#xff1a;自動創建與基礎單圖布局類別二&#xff1a;規律網格布局 - 主力軍類別三&#xff1a;復雜網格布局…

【C#】在一個任意旋轉的矩形(由四個頂點定義)內繪制一個內切橢圓

核心點&#xff1a;在一個任意旋轉的矩形&#xff08;由四個頂點定義&#xff09;內繪制一個內切橢圓 實現步驟 計算矩形中心&#xff1a;作為旋轉中心點 創建橢圓路徑&#xff1a;在未旋轉狀態下定義橢圓 應用旋轉變換&#xff1a;使用矩陣繞中心點旋轉路徑 繪制變換后的路…

洛谷 P2052 [NOI2011] 道路修建-普及/提高-

P2052 [NOI2011] 道路修建 題目描述 在 W 星球上有 nnn 個國家。為了各自國家的經濟發展&#xff0c;他們決定在各個國家之間建設雙向道路使得國家之間連通。但是每個國家的國王都很吝嗇&#xff0c;他們只愿意修建恰好 n?1n - 1n?1 條雙向道路。 每條道路的修建都要付出一定…

springboot連接不上redis,但是redis客戶端是能連接上的

除了常規排查&#xff0c;還有一個就是檢查配置文件格式。這個舊版本格式會導致讀取不到配置&#xff0c;spring:# 對應 RedisProperties 類redis:host: 127.0.0.1port: 6379 # password: 123456 # Redis 服務器密碼&#xff0c;默認為空。生產中&#xff0c;一定要設置 Red…

GitBook 完整使用指南:從安裝到部署

文章目錄 環境準備 Node.js 安裝 GitBook CLI 安裝 項目初始化 創建項目結構 (可選) npm 初始化 目錄結構配置 開發與調試 本地服務啟動 構建靜態文件 配置文件詳解 插件系統 常用插件推薦 插件安裝與配置 自定義樣式 部署指南 GitHub Pages 部署 Netlify 部署 高級功能 多語言…

VS安裝 .NETFramework,Version=v4.6.x

一、前言 在使用VS2019打開項目時提示MSB3644 找不到 .NETFramework,Versionv4.6.2 的引用程序集的錯誤 二、解決方案 1.百度......找到了解決方法了 2.打開Visual Studio Install 3.點擊修改 4.點擊單個組件&#xff0c;安裝相對應的版本即可

Visual Studio Code中launch.json的解析筆記

<摘要> launch.json 是 Visual Studio Code 中用于配置調試任務的核心文件。本文解析了其最常用的配置字段&#xff0c;涵蓋了基本調試設置、程序控制、環境配置和高級調試功能。理解這些字段能幫助開發者高效配置調試環境&#xff0c;提升開發效率。<解析> 1. 背景…

試試 Xget 加速 GitHub 克隆倉庫

引言 在全球化軟件開發環境中&#xff0c;開發者經常面臨跨地域訪問GitHub等平臺的網絡挑戰&#xff1a;下載速度緩慢、連接不穩定、甚至完全無法訪問。這些問題嚴重影響了開發效率和協作體驗。Xget作為一個開源的高性能資源獲取加速引擎&#xff0c;通過智能路由、多節點分發…

優雅處理Go中的SIGTERM信

在Go語言中優雅處理SIGTERM信號需通過os/signal包實現&#xff0c;核心流程包括信號注冊、異步監聽和資源清理。SIGTERM 是一種常見的進程終止信號&#xff0c;它允許程序在退出前執行必要的清理操作。與之不同&#xff0c;SIGKILL 信號無法被進程捕獲或忽略。未處理的 SIGTERM…

《R for Data Science (2e)》免費中文翻譯 (第6章) --- scripts and projects

寫在前面 本系列推文為《R for Data Science (2)》的中文翻譯版本。所有內容都通過開源免費的方式上傳至Github&#xff0c;歡迎大家參與貢獻&#xff0c;詳細信息見&#xff1a; Books-zh-cn 項目介紹&#xff1a; Books-zh-cn&#xff1a;開源免費的中文書籍社區 r4ds-zh-cn …

GitHub Spark深度體驗:是革命前夜,還是又一個“大廠玩具”?

最近&#xff0c;AI 編碼工具層出不窮&#xff0c;幾乎每天都有新概念誕生。而當 GitHub 這樣的行業巨頭攜“Vibe Coding”概念入場時&#xff0c;所有開發者的期待值都被瞬間拉滿。GitHub Spark&#xff0c;一個承諾能用自然語言將你的想法直接變成全棧應用的工具&#xff0c;…

科學研究系統性思維的方法體系:研究設計相關模版

一、研究設計方案模板 模板說明本模板基于《研究設計原理與方法》深度解讀報告的理論框架&#xff0c;幫助研究者制定系統性的研究設計方案。模板整合了因果推斷理論、效度控制框架和現代實驗設計原理。1. 研究問題界定與假設陳述 1.1 研究問題核心要素 研究問題&#xff08;明…

法律審查prompt收集

當前DeepSeek等大模型已經具備初步合同審查能力。 這里收集合同審查及相關prompt&#xff0c;不管是做Coze等Agent&#xff0c;還是開發LLM應用&#xff0c;都有可能用到這些prompt。 https://github.com/LeeXYZABC/law_propmpts.git 1 條款分析 system_prompt&#xff0c;L…