首先引入JavaMail依赖,然后配置SMTP服务器信息,接着使用JavaMail API构建并发送带验证链接的邮件,最后生成唯一token并存储以供后续验证;整个流程确保用户注册邮箱的真实性与安全性。
用户注册时的邮件验证是保障账号安全的重要环节。Java可以通过SMTP协议发送验证邮件,结合JavaMail API实现这一功能。下面通过一个完整实例讲解如何在用户注册后发送带验证链接的邮件。
1. 添加JavaMail依赖
使用Maven管理项目时,在pom.xml中引入JavaMail依赖:
javax.mail
该库提供了发送邮件所需的核心类,如Session、Message、Transport等。
2. 配置SMTP服务器信息
以QQ邮箱为例,配置SMTP参数。需提前开启SMTP服务并获取授权码:
String host = "smtp.qq.com";String port = "587";
String username = "your_email@qq.com";
String password = "your_authorization_code";
注意:密码不是登录密码,而是邮箱提供的“授权码”。
3. 构建并发送验证邮件
核心代码如下:
Properties props = new Properties();props.put("mail.smtp.host", host);
props.put("mail.smtp.port", port);
props.put("mail.smtp.auth", "true");
props.put("mail.smtp.starttls.enable", "true");
Session session = Session.getInst

protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
try {
Message message = new MimeMessage(session);
message.setFrom(new InternetAddress(username));
message.setRecipients(Message.RecipientType.TO, InternetAddress.parse("user@example.com"));
message.setSubject("邮箱验证");
String verifyLink = "http://yourdomain.com/verify?token=abc123";
message.setText("请点击链接完成验证:" + verifyLink);
Transport.send(message);
System.out.println("验证邮件已发送");
} catch (MessagingException e) {
e.printStackTrace();
}
邮件内容中的token应为后台生成的唯一令牌,用于后续验证请求合法性。
4. 生成验证令牌与处理验证请求
注册时生成随机token并存入数据库或缓存(如Redis),设置过期时间(例如10分钟):
String token = UUID.randomUUID().toString();// 存储 token 和用户邮箱的映射关系
redisTemplate.opsForValue().set("verify:" + token, email, 10, TimeUnit.MINUTES);
用户点击验证链接后,服务端根据token查找对应邮箱,确认无误后激活账户。
基本上就这些。整个流程包括依赖引入、SMTP配置、邮件发送和token验证,关键在于安全地生成和管理验证令牌,确保链接一次性有效。实际项目中可加入重发机制和防刷限制。不复杂但容易忽略细节,比如超时处理和异常捕获。








