javax.mail.AuthenticationFailedException Java Mail

左心房为你撑大大i 提交于 2019-12-01 02:51:18

问题


I have made a little program that send a message to my email account. Most of my code seems to work fine. However, I have encounter the AuthenticationFailedException when I am my code hit transport.send in my program. I am not sure why because I think I have everything set up correctly. Here is my code.

JavaEmail.java

public static void main (String[] args) throws Exception{
                //intialize logger 
protected static Logger logger = LogManager.getLogger(JavaEmail.class.getName());

//smtp related parameters 
private static String smtpUseremail;
private static String smtpReceiverEmailAddress;
private static String smtpUserpassword;
private static String smtpPortnumber;
private static String smtpHost;

private static String emailSubject;

//stack error message variable 
private static String message;

        try {

            logger.info("-----------------------------");
            logger.info("---------Starting up---------");
            logger.info("-----------------------------");

            initialize();

            String body = "This is a test";

            logger.info("Start to connect to email server");

            sendFromGmail(smtpUseremail, smtpUserpassword, smtpReceiverEmailAddress, emailSubject, body);



           // System.out.println("error message: " + message);

            logger.info("Email Sent");


        }
        catch (Exception e){
            logger.error(e);

            // message = e.toString();

            throw e;


        }
    }

    //Setting up Email Server
    private static void sendFromGmail(String from, String pass, String to, String subject, String body) {


        Properties props = PropertiesUtil.loadProperties("main.properties");

        props.put("mail.smtp.auth", "true");
        props.put("mail.smtp.starttls.enable", "true");
        props.put("mail.smtp.host", smtpHost);
        props.put("mail.smtp.port", smtpPortnumber);

        Session session = Session.getInstance(props,
                  new javax.mail.Authenticator() {
                    protected PasswordAuthentication getPasswordAuthentication() {
                        return new PasswordAuthentication(smtpUseremail, smtpUserpassword);
                    }
                  });

        MimeMessage message = new MimeMessage(session);



        try{


            message.setFrom(new InternetAddress(from));

            message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));


            message.setSubject(subject);

            message.setText(body);

            Transport.send(message);

            logger.info("Message has been delievered, check your mail");

        }

        catch (MessagingException e) {
            logger.error("Messaging Exception");

            throw new RuntimeException(e);
        }
    }


    //Initializing Properties
    private static void initialize() throws Exception  {

        Properties props = PropertiesUtil.loadProperties("main.properties");

        //smtp set up
        smtpPortnumber = props.getProperty("portNumber");
        smtpReceiverEmailAddress = props.getProperty("recipientEmailAddress");
        smtpUseremail = props.getProperty("userEmailAddress");
        smtpUserpassword = props.getProperty("userPassword");
        smtpHost = props.getProperty("emailHost");
        emailSubject = props.getProperty("");

    }

}

main.properties

portNumber = 465
recipientEmailAddress = my@gmail.com
userPassword = secert
userEmailAddress = my@gmail.com
emailHost = smtp.gmail.com

error

Exception in thread "main" java.lang.RuntimeException: javax.mail.AuthenticationFailedException: 534-5.7.14 <https://accounts.google.com/ContinueSignIn?sarp=1&scc=1&plt=AKgnsbvWE
    534-5.7.14 HIW4hBxefM-JI-wxqEK6ru2lJstC10IedXvhU_Tzbft1IqPFsot0wfjAWkrX2-gLIEG0NZ
    534-5.7.14 V45KWaeagzWTb_v1nAe-BOZSR6YzPHQ7-cYVGYplvcaexmFziL3IMRgkCalmn-5FjreRkm
    534-5.7.14 PjtRPd9nmjcosX0ce4DXSGn_y-qGOsW-ehOp2U3eQkSReObXi-a80ywNWiy3QuiV56f61h
    534-5.7.14 yz8bmLpugqIYhh7DiNd6HpwvNHAo> Please log in via your web browser and
    534-5.7.14 then try again.
    534-5.7.14  Learn more at
    534 5.7.14  https://support.google.com/mail/answer/78754 ob15sm12759947pdb.52 - gsmtp

        at emailNotification.JavaEmail.sendFromGmail(JavaEmail.java:140)
        at emailNotification.JavaEmail.main(JavaEmail.java:63)
    Caused by: javax.mail.AuthenticationFailedException: 534-5.7.14 <https://accounts.google.com/ContinueSignIn?sarp=1&scc=1&plt=AKgnsbvWE
    534-5.7.14 HIW4hBxefM-JI-wxqEK6ru2lJstC10IedXvhU_Tzbft1IqPFsot0wfjAWkrX2-gLIEG0NZ
    534-5.7.14 V45KWaeagzWTb_v1nAe-BOZSR6YzPHQ7-cYVGYplvcaexmFziL3IMRgkCalmn-5FjreRkm
    534-5.7.14 PjtRPd9nmjcosX0ce4DXSGn_y-qGOsW-ehOp2U3eQkSReObXi-a80ywNWiy3QuiV56f61h
    534-5.7.14 yz8bmLpugqIYhh7DiNd6HpwvNHAo> Please log in via your web browser and
    534-5.7.14 then try again.
    534-5.7.14  Learn more at
    534 5.7.14  https://support.google.com/mail/answer/78754 ob15sm12759947pdb.52 - gsmtp

        at com.sun.mail.smtp.SMTPTransport$Authenticator.authenticate(SMTPTransport.java:809)
        at com.sun.mail.smtp.SMTPTransport.authenticate(SMTPTransport.java:752)
        at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:669)
        at javax.mail.Service.connect(Service.java:317)
        at javax.mail.Service.connect(Service.java:176)
        at javax.mail.Service.connect(Service.java:125)
        at javax.mail.Transport.send0(Transport.java:194)
        at javax.mail.Transport.send(Transport.java:124)
        at emailNotification.JavaEmail.sendFromGmail(JavaEmail.java:130)
        ... 1 more

回答1:


Go to browser then Login to your gmail account which you trying in your code, then go to the this link https://www.google.com/settings/security/lesssecureapps

You will see

You should click TURN ON .



来源:https://stackoverflow.com/questions/32303910/javax-mail-authenticationfailedexception-java-mail

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!