需要使Javamail对于gmail身份验证更加安全

需要使Javamail对于gmail身份验证更加安全,java,email,smtp,gmail,jakarta-mail,Java,Email,Smtp,Gmail,Jakarta Mail,我已经编写了一个从java发送简单邮件的代码(javamail/jaf)。运行该程序后,我收到了一封来自谷歌的电子邮件,说我的帐户正被不安全的设备/应用程序访问。然后我不得不更改我的gmail帐户的设置,允许登录“不太安全的应用”选项。然后我收到了来自该项目的电子邮件 我需要在不更改选项的情况下发送电子邮件,允许在我的帐户中使用“不太安全的应用程序”选项。请帮忙 我的代码是: import java.util.Properties; import javax.mail.Message; impo

我已经编写了一个从java发送简单邮件的代码(javamail/jaf)。运行该程序后,我收到了一封来自谷歌的电子邮件,说我的帐户正被不安全的设备/应用程序访问。然后我不得不更改我的gmail帐户的设置,允许登录“不太安全的应用”选项。然后我收到了来自该项目的电子邮件

我需要在不更改选项的情况下发送电子邮件,允许在我的帐户中使用“不太安全的应用程序”选项。请帮忙

我的代码是:

import java.util.Properties;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

public class SendMailSSL {
    public static void main(String[] args) {
        Properties props = new Properties();
        props.put("mail.smtp.host", "smtp.gmail.com");
        props.put("mail.smtp.socketFactory.port", "465");
        props.put("mail.smtp.socketFactory.class",
                "javax.net.ssl.SSLSocketFactory");
        props.put("mail.smtp.auth", "true");
        props.put("mail.smtp.port", "465");

        Session session = Session.getDefaultInstance(props,
            new javax.mail.Authenticator() {
                protected PasswordAuthentication getPasswordAuthentication() {
                    return new PasswordAuthentication("*****@gmail.com","*******");
                }
            });

        try {

            Message message = new MimeMessage(session);
            message.setFrom(new InternetAddress("*****@gmail.com"));
            message.setRecipients(Message.RecipientType.TO,
                    InternetAddress.parse("*****@gmail.com"));
            message.setSubject("Testing Subject");
            message.setText("Dear User," +
                    "\n\n No spam to my email, please!");

            Transport.send(message);

            System.out.println("Done");

        } catch (MessagingException e) {
            throw new RuntimeException(e);
        }
    }
}

Gmail避免这种情况的唯一方法是使用OAuth2.0身份验证。你可以通过这个链接阅读

我不知道为什么我的答案只有一个链接被删除,但这个答案只有一个链接没有被删除。无论如何,您可以找到更多关于在JavaMail中使用OAuth2的信息。