2016-09-23 48 views
0

我有一個Spring-Boot (1.4.0)應用程序,我使用的是springframework.boot:spring-boot-starter-mailAuthenticationFailedException: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再次開始。

有什麼建議嗎?

回答

0

我剛解決了它。

我連接太多次,而且超出了電子郵件服務器的連接池。所以我所做的是將getInbox()getSession()定義爲@BeanInject他們到我的EmailService

現在它只創建連接一次。它工作正常。