MFA验证方式(1)-邮箱验证

1.背景

现在很多只进行简单的账号密码登录验证,其实是很容易被黑客攻击的。所以就出现了MFA(Multi-Factor Authentication),MFA验证也有很多方式,比如邮箱、短信、TOTP(Time-based One-Time Password)、生物验证等。

今天讲解一个最基础的邮箱验证。

2. 上代码逻辑

 前端发送需要短信验证  -----》  后端随机生成一个6为的验证码并发送邮箱  ------》 建议放到reids设置一个有效时间  -------》 前端将验证码发送过来去redis取出进行校验。

import freemarker.template.Configuration;
import freemarker.template.Template;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.mail.SimpleMailMessage;
import org.springframework.mail.javamail.JavaMailSender;
import org.springframework.mail.javamail.MimeMessageHelper;
import org.springframework.stereotype.Component;
import org.springframework.ui.freemarker.FreeMarkerTemplateUtils;

import javax.mail.internet.MimeMessage;
import java.util.Map;

@Component
@Slf4j
public class MailUtil {

    @Autowired
    private Configuration freeMarkerConfig;

    @Autowired
    private JavaMailSender mailSender;

    @Value("${spring.mfa.mail.from}")
    private String from;

    public void sendMail(String to,String subject, String content,
                         String templateName, Map<String, Object> model){
        log.info("Entering sendMail() method, begin to send email [from:" + from + ", to:" + to + ", subject:" + subject + "]");
        try{
            if (templateName != null) {
                Template template = freeMarkerConfig.getTemplate(templateName);
                content = FreeMarkerTemplateUtils.processTemplateIntoString(template, model);
            }
            SimpleMailMessage message = new SimpleMailMessage();
            message.setFrom(from);
            if (to.contains(",") && to.contains("@")) {
                String[] toMails = to.split(",");
                message.setTo(toMails);
            } else{
                message.setTo(to);
            }
            message.setSubject(subject);
            message.setText(content);

            mailSender.send(message);
        }catch (Exception e) {
            log.error(ExceptionUtil.printStackTrace(e));
        }
    }


    public void sendMimeMail(String to, String subject, String content, String templateName, Map<String, Object> model) {
        log.info("Entering sendMimeMail() mfilePathethod, begin to send email [from:" + from + ", to:" + to + ", subject:" + subject + "]");
        try { 前端发送需要短信验证  -----》  后端随机生成一个6为的验证码并发送邮箱  ------》 建议放到reids设置一个有效时间  -------》 前端将验证码发送过来去redis取出进行校验。
            if (null != templateName) {
                Template template = freeMarkerConfig.getTemplate(templateName);
                content = FreeMarkerTemplateUtils.processTemplateIntoString(template, model);
            }
            MimeMessage mimeMessage = mailSender.createMimeMessage();
            MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
            helper.setFrom(from);
            if (to.contains(",") && to.contains("@")) {
                String[] toMails = to.split(",");
                helper.setTo(toMails);
            } else {
                helper.setTo(to);
            }
            helper.setSubject(subject);
            helper.setText(content,true);
            /*FileSystemResource file = new FileSystemResource(filePath);
            helper.addAttachment(Objects.requireNonNull(file.getFilename()), file);*/
            mailSender.send(mimeMessage);
        } catch (Exception e) {
            log.error("send mail failed.:{}", e.getMessage());
        }
    }

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaMail中实现MFA验证需要您先在您的邮件服务提供商的账户设置中启用MFA功能。然后,您需要在JavaMail中设置您的账户凭据以及MFA验证所需的其他参数。 以下是一个使用Google邮件(Gmail)服务的JavaMail MFA验证示例: ```java import java.util.Properties; import javax.mail.*; import javax.mail.internet.*; public class JavaMailMFAExample { public static void main(String[] args) throws Exception { String username = "your_email_address@gmail.com"; String password = "your_password"; String mfaToken = "your_mfa_token"; // MFA token generated by your authenticator app Properties props = new Properties(); props.put("mail.smtp.auth.mechanisms", "XOAUTH2"); props.put("mail.smtp.auth.xoauth2.disable", "false"); props.put("mail.smtp.auth.login.disable", "true"); props.put("mail.smtp.auth.plain.disable", "true"); props.put("mail.smtp.starttls.enable", "true"); props.put("mail.smtp.host", "smtp.gmail.com"); props.put("mail.smtp.port", "587"); Session session = Session.getInstance(props); session.setDebug(true); Authenticator auth = new Authenticator() { protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication(username, password + mfaToken); } }; MimeMessage msg = new MimeMessage(session); msg.setFrom(new InternetAddress("your_email_address@gmail.com")); msg.setRecipients(Message.RecipientType.TO, InternetAddress.parse("recipient_email_address")); msg.setSubject("Test email"); msg.setText("Hello, this is a test email."); Transport transport = session.getTransport("smtp"); transport.connect("smtp.gmail.com", username, password + mfaToken); transport.sendMessage(msg, msg.getAllRecipients()); transport.close(); System.out.println("Message sent successfully."); } } ``` 在此示例中,您需要用您的账户凭据替换示例代码中的`username`和`password`变量。在发送电子邮件之前,您需要使用您的MFA令牌替换示例代码中的`mfaToken`变量。此外,您需要在JavaMail的配置中设置`mail.smtp.auth.mechanisms`属性为`XOAUTH2`,并将`mail.smtp.auth.xoauth2.disable`、`mail.smtp.auth.login.disable`和`mail.smtp.auth.plain.disable`属性设置为`false`。 请注意,不同的邮件服务提供商可能需要不同的配置参数来启用MFA验证。因此,建议您查阅您的邮件服务提供商的文档以了解如何在JavaMail中实现MFA验证

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值