Не удается прочитать электронную почту office365, используя javaMail и IMAPS - PullRequest
0 голосов
/ 24 января 2019

Я сталкиваюсь с ошибкой при использовании javaMail & IMAPS для чтения электронных писем на учетной записи электронной почты моей компании, размещенной в офисе 365.

Я использую этот тестовый класс:

public class TestMail {

public static void main(String[] args) {
    // TODO Auto-generated method stub
    Properties props = System.getProperties();               
    props.put("mail.imaps.auth.plain.disable","true"); 
    props.setProperty("mail.imaps.timeout", "100000");
    props.setProperty("mail.imaps.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
    props.setProperty("mail.imaps.socketFactory.fallback", "false");
    props.setProperty("mail.imaps.ssl.enable", "true");

         try {
              Session session = Session.getInstance(props, null);
              session.setDebug(true);
              Store store = session.getStore("imaps");
              store.connect("outlook.office365.com", 993, "my-name@mycompagny.com", "MY_PASSWORD");
              System.out.println(store);
              Folder inbox = store.getFolder("Inbox");
              inbox.open(Folder.READ_ONLY);
              Message messages[] = inbox.getMessages();
              for(Message message:messages) {
                   System.out.println(message);
              }
    }  catch (Exception e) {
         e.printStackTrace();
         System.exit(2);
    }
}

}

Я получаю следующую ошибку:

DEBUG: setDebug: JavaMail version 1.4.7
DEBUG: getProvider() returning javax.mail.Provider[STORE,imaps,com.sun.mail.imap.IMAPSSLStore,Oracle]
DEBUG IMAPS: mail.imap.fetchsize: 16384
DEBUG IMAPS: mail.imap.ignorebodystructuresize: false
DEBUG IMAPS: mail.imap.statuscachetimeout: 1000
DEBUG IMAPS: mail.imap.appendbuffersize: -1
DEBUG IMAPS: mail.imap.minidletime: 10
DEBUG IMAPS: disable AUTH=PLAIN
DEBUG IMAPS: trying to connect to host "outlook.office365.com", port 993, isSSL true
* OK The Microsoft Exchange IMAP4 service is ready. [UABSADIAUAAyADYANABDAEEAMAAwADAANAAuAEYAUgBBAFAAMgA2ADQALgBQAFIATwBEAC4ATwBVAFQATABPAE8ASwAuAEMATwBNAA==]
A0 CAPABILITY
* CAPABILITY IMAP4 IMAP4rev1 AUTH=PLAIN AUTH=XOAUTH2 SASL-IR UIDPLUS ID UNSELECT CHILDREN IDLE NAMESPACE LITERAL+
A0 OK CAPABILITY completed.
DEBUG IMAPS: AUTH: PLAIN
DEBUG IMAPS: AUTH: XOAUTH2
DEBUG IMAPS: protocolConnect login, host=outlook.office365.com, user=my-name@mycompagny.com, password=<non-null>
DEBUG IMAPS: LOGIN command trace suppressed
DEBUG IMAPS: LOGIN command result: A1 NO LOGIN failed.
javax.mail.AuthenticationFailedException: LOGIN failed.
    at com.sun.mail.imap.IMAPStore.protocolConnect(IMAPStore.java:661)
    at javax.mail.Service.connect(Service.java:295)
    at com.afklm.bagdss.task.TestMail.main(TestMail.java:25)
...