我有一个Spring-Boot (1.4.0)
应用程序,我使用的是springframework.boot:spring-boot-starter-mail
。AuthenticationFailedException:AUTHENTICATE失败经过一些连接
我有一个方法注释@Scheduled
每隔一段时间检查我的收件箱。
这是我如何得到我的收件箱:
private static Folder getInbox() throws MessagingException {
final String protocol = "mail.store.protocol";
final String storeType = "imaps";
final String email = "email";
final String password = "password";
final String connect = "webmail.company.com";
final String folder = "INBOX";
final Properties props = new Properties();
props.setProperty(protocol, storeType);
final Session session = Session.getInstance(props, null);
final Store store = session.getStore();
store.connect(connect, email, password);
final Folder inbox = store.getFolder(folder);
inbox.open(Folder.READ_WRITE);
return inbox;
}
然后,我有这样的:
@Scheduled(fixedRate = 10000)
@Override
public void checkEmailCreateCompanyAndSendCsv() throws MessagingException, IOException {
log.info("Checking e-mail...");
final Folder inbox = getInbox();
final Flags seen = new Flags(Flags.Flag.SEEN);
final FlagTerm unseenFlagTerm = new FlagTerm(seen, false);
inbox.getMessages();
final Message messages[] = inbox.search(unseenFlagTerm);
.....
.....
}
当应用程序运行时一切都很正常,但是一段时间后(约7后8 E-邮件检查)它开始引发异常:
javax.mail.AuthenticationFailedException:AUTHENTICATE失败。在 com.sun.mail.imap.IMAPStore.protocolConnect(IMAPStore.java:717)at javax.mail.Service.connect(Service.java:366)at javax.mail.Service.connect(Service.java: 246)在 com.opessoftware.crs.selfcertification.services.EmailServiceBasic.getInbox(EmailServiceBasic.java:183) 在 com.opessoftware.crs.selfcertification.services.EmailServiceBasic.checkEmailCreateCompanyAndSendCsv(EmailServiceBasic.java:50) 在太阳.reflect.GeneratedMethodAccessor28.invoke(未知来源)处 org.springframework sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在java.lang.reflect.Method.invoke(Method.java:498)。 scheduling.support.ScheduledMethodRunnable.run(S cheduledMethodRunnable.java:65) 在 org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) 在 java.util.concurrent.Executors $ RunnableAdapter.call(Executors.java:511) 在java.util.concurrent.FutureTask.runAndReset在 java.util.concurrent.ScheduledThreadPoolExecutor中的$ ScheduledFutureTask.access(FutureTask.java:308) $ 301(ScheduledThreadPoolExecutor.java:180) 在 java.util.concurrent.ScheduledThreadPoolExecutor中的$ ScheduledFutureTask .run(ScheduledThreadPoolExecutor.java:294) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 在 java.util.concurrent.ThreadPoolExecutor中的$ Worker.run(ThreadPoolExecutor.java:617) 在java.lang.Thread.run(Thread.java:745)
如果我停止应用程序并运行它再次失败并且Cicle再次开始。
有什么建议吗?