java实现qq邮箱验证码案例

  1. 开启SMTP服务

    在 QQ 邮箱里的 设置->账户里开启 SMTP 服务

    注意开启完之后,QQ 邮箱会生成一个授权码,在代码里连接邮箱使用这个授权码而不是原始的邮箱密码,这样可以避免使用明文密码。

  2. 在application.properties中配置邮件发送服务器信息:
spring.mail.host=smtp.qq.com # 邮箱SMTP服务地址
spring.mail.port=465 # 端口号
spring.mail.username=your_email@qq.com # 发送邮件的邮箱地址
spring.mail.password=%%%%%%…… # 发送邮件的邮箱密码(授权码)
spring.mail.properties.mail.smtp.auth=true # 邮箱SMTP服务需要认证
spring.mail.properties.mail.smtp.ssl.enable=true # 对于QQ邮箱,需要启用SSL加密

maven依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-mail</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
@Service
public class MailService {
    @Autowired
    private JavaMailSender mailSender; // JavaMailSender对象用于发送邮件

    @Autowired
    private RedisTemplate<String, String> redisTemplate; // RedisTemplate对象用于保存验证码
    //生成随机验证码通过自己配置的邮箱发送到目标邮箱
    public Result sendMail(String email) {
        // 在redis中生成6位随机验证码,过期时间为10分钟
        String code = String.valueOf(new Random().nextInt(899999) + 100000);
        redisTemplate.opsForValue().set(email, code, 10, TimeUnit.MINUTES);

        // 创建一个MimeMessage对象
        MimeMessage message = mailSender.createMimeMessage();

        MimeMessageHelper helper;
        try {
            helper = new MimeMessageHelper(message, true);
            helper.setFrom("your_email@qq.com"); // 发件人邮箱
            helper.setTo(email); // 收件人邮箱
            helper.setSubject("验证码"); // 邮件主题
            helper.setText("您的验证码为:" + code); // 邮件内容

            mailSender.send(message); // 发送邮件
            return Result.success("验证码已发送");
        } catch (MessagingException e) {
            e.printStackTrace();
            return Result.error("发送失败,请检查邮箱地址是否正确");
        }
    }

    public Result verifyCode(String email, String code) {
        String savedCode = redisTemplate.opsForValue().get(email);
        if (savedCode == null || !savedCode.equals(code)) {
            return Result.error("验证码错误");
        }
        return Result.success();
    }
}

  1. 在Controller中调用MailService类中的方法:
@RestController
@RequestMapping("/mail")
public class MailController {
    @Autowired
    private MailService mailService;

    @PostMapping("/send")
    public Result sendMail(@RequestParam String email) {
        return mailService.sendMail(email);
    }

    @PostMapping("/verify")
    public Result verifyCode(@RequestParam String email, @RequestParam String code) {
        return mailService.verifyCode(email, code);
    }
}

  1. 在前端页面中使用ajax请求来发送邮件和验证验证码:
//获取验证码
function sendMail() {
    var email = $('#email').val();
    $.ajax({
        url: '/mail/send',
        type: 'POST',
        data: {
            email: email
        },
        success: function (data) {
            alert(data.message);
        },
        error: function (error) {
            alert(error.responseText);
        }
    });
}
//检验验证码是否正确
function verifyCode() {
    var email = $('#email').val();
    var code = $('#code').val();
    $.ajax({
        url: '/mail/verify',
        type: 'POST',
        data: {
            email: email,
            code: code
        },
        success: function (data) {
            alert('验证码正确');
        },
        error: function (error) {
            alert(error.responseText);
        }
    });
}

以上就实现了基本的邮箱发送功能,如果您想做登陆验证,可以在该基础上拓展来实现

java相关问题、idea免费激活、软件设计师软考相关资料,java学习过程中用到的软件可以通过关注如下公众号获取

java小菜鸟资料分享

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只java小菜鸡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值