【瑞吉外卖】手机号验证码登录(用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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈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…