当前位置: 首页 > article >正文

spring项目使用邮箱验证码校验

本项目采用免费QQ邮箱验证码方式进行登录安全的校验。

前期工作

申请邮箱安全授权码

打开QQ邮箱官网点击设置

进入设置页面后点击账户按钮

 进入账户后一直往下拉页面找到POP3服务栏,然后点击管理服务(如果没有开启服务需要先开启服务,按照邮箱提示操作即可)

进入管理服务页面后如果没有授权码,点击生成授权码,如果有即可进入授权码管理页面查看。

授权码过一段时间会自动过期,需要重新申请。

 

项目中导入邮箱依赖

复制以下maven坐标到项目中,maven会自动导入其他依赖的坐标

	<!--邮箱-->
        <dependency>
          <groupId>org.apache.commons</groupId>
          <artifactId>commons-email</artifactId>
          <version>1.5</version>
        </dependency>

定义配置类

完整代码如下,有注解,我将需要修改的地方单独列在后面

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.mail.*;
import javax.mail.internet.AddressException;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.Properties;
import java.util.Random;

@Controller
public class MailcodeServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	// 得到随机的字符串,用于发送验证码的内容
	public String getNumbers(int size) {
		String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
		String numString = "";
		Random r = new Random();
		for (int i = 0; i < size; i++) {
			char c = str.charAt(r.nextInt(str.length()));
			numString = numString + c;
		}
		return numString;
	}
	@RequestMapping("/email")
	public void email(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//		response.setCharacterEncoding("UTF-8");
		// 设置返回的编码格式,同时设置客户端和服务端的编码格式
		response.setContentType("application/json; charset=UTF-8");

		String email = request.getParameter("email");
		System.out.println("email" + email);

		String emailString = getNumbers(5);
		System.out.println("验证码" + emailString);

		HttpSession session = request.getSession();

		session.setAttribute("email", email);
		session.setAttribute("emailString", emailString);


		// 创建Properties类用于记录邮箱的一些属性
		Properties props = new Properties();
		// 表示SMTP发送邮件,必须进行身份验证
		props.put("mail.smtp.auth", "true");
		// 此处填写SMTP服务器
		props.put("mail.smtp.host", "smtp.qq.com");
		// 端口号,QQ邮箱端口465或587
		props.put("mail.smtp.port", "587");
		// 此处填写,写信人的账号
		props.put("mail.user", "3131019721@qq.com");
		// 此处填写16位STMP口令
		props.put("mail.password", "qzsmlbypynsedc");

		// 构建授权信息,用于进行SMTP进行身份验证
		Authenticator authenticator = new Authenticator() {
			protected PasswordAuthentication getPasswordAuthentication() {
				// 用户名、密码
				String userName = props.getProperty("mail.user");
				String password = props.getProperty("mail.password");
				return new PasswordAuthentication(userName, password);
			}
		};
		// 使用环境属性和授权信息,创建邮件会话
		Session mailSession = Session.getInstance(props, authenticator);
		// 创建邮件消息
		MimeMessage message = new MimeMessage(mailSession);
		try {
			// 设置发件人
			InternetAddress form = new InternetAddress(props.getProperty("mail.user"));
			message.setFrom(form);
			// 设置收件人的邮箱
			InternetAddress to = new InternetAddress(email);
			message.setRecipient(MimeMessage.RecipientType.TO, to);
			// 设置邮件标题
			message.setSubject("资产管理系统验证码");
			// 设置邮件内容体
			message.setContent("验证码:" + emailString, "text/html;charset=UTF-8");
			// 发送邮件
			Transport.send(message);
			response.getWriter().write("{\"message\": \"验证码已发送,请查收!\"}");
		} catch (AddressException e) {
			session.setAttribute("messagesigh", "邮箱输入有误");
			e.printStackTrace();
			response.getWriter().write("{\"message\": \"发送验证码失败!\"}");
		} catch (MessagingException e) {
			session.setAttribute("messagesigh", "邮箱输入有误");
			e.printStackTrace();
			response.getWriter().write("{\"message\": \"发送验证码失败!\"}");
		}
	}
}

需要修改的地方,只需将写信人的账户改成自己的,然后在STMP口令,也就是申请的授权码复制即可。

	// 此处填写,写信人的账号
		props.put("mail.user", "3131019721@qq.com");
	// 此处填写16位STMP口令
		props.put("mail.password", "qzsmlbypynsedc");

前端Ajax代码

<!-- 验证码输入框 -->
	<div class="form-group has-feedback">
		<input required type="text" name="captcha" class="form-control" id="captcha" placeholder="验证码">
		<span class="glyphicon glyphicon-question-sign form-control-feedback"></span>
	</div>
<!-- 发送验证码的按钮 -->
	<div class="form-group">
		<button type="button" class="btn btn-success" id="send-code">发送验证码</button>
	</div>


<!-- jQuery代码 -->

$(document).ready(function() {
			$('#send-code').click(function(e) {
				e.preventDefault(); // 防止表单的默认提交行为
                //获取输入框邮箱值
				var email = $('#email').val();
                //邮箱格式校验
				var emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
				if (emailPattern.test(email)) {
					$.ajax({
						url: '/email',
						type: 'POST',
						data: { email: email},
						dataType: 'json',
						success: function(response) {
								console.log(response)
						},
						error: function(e) {
							console.log(e)
						}
					});
				} else {
						console.log("输入错误")
				}
			});
		});


http://www.kler.cn/news/293970.html

相关文章:

  • Vue3状态管理Pinia
  • APS开源源码解读: 排程工具 optaplanner
  • PHP批量修改MySQL数据表字符集为utf8mb4/utf8mb4_unicode_ci
  • 全网首发!!!opencv三通道Mat点云转halcon点云—HTuple类型
  • linux编译出现报错
  • ★ 算法OJ题 ★ 力扣3 - 无重复字符的最长子串
  • 百家云 BRTC:革新华为 HarmonyOS NEXT 系统的实时通信体验
  • ctfshow-php特性(web123-web150plus)
  • 安卓玩机工具-----ADB方式的刷机玩机工具“秋之盒”’ 测试各项功能预览
  • SpinalHDL之数据类型(一)
  • 【LeetCode】11.盛最多水的容器
  • UE4_后期处理_后期处理材质及后期处理体积三—遮挡物体描边显示
  • 网络安全与恶意攻击:如何应对?
  • 2024 年高教社杯全国大学生数学建模竞赛 C 题 农作物的种植策略 完整参考论文
  • Jenkins+Svn+Vue自动化构建部署前端项目(保姆级图文教程)
  • [数据集][目标检测]智慧农业草莓叶子病虫害检测数据集VOC+YOLO格式4040张9类别
  • 仿论坛项目--Kafka,构建TB级异步消息系统
  • IOS 20 发现界面(UITableView)歌单列表(UICollectionView)实现
  • 51单片机-第十二节-LCD1602液晶显示屏
  • MyBatis-Plus 框架 QueryWrapper UpdateWrapper 方法修复sql注入漏洞事件
  • 2024社区版IDEA springboot日志输出颜色
  • Excel数据导入MySQL数据库的完整指南
  • 4.6 Sensors -- useMouse
  • EmguCV学习笔记 C# 10.2 人脸识别 FaceRecgnizer类
  • 太速科技-基于Kintex-7 XC7K325T的FMC USB3.0四路光纤数据转发卡
  • 解决MongoDB创建用户报错command createUser requires authentication
  • 结合AI图片增强、去背景,如何更好的恢复旧照片老照片?
  • 一台电脑对应一个IP地址吗?‌探讨两台电脑共用IP的可能性
  • Oracle数据库使用和维护的技巧与经验
  • Elasticsearch文档值