2010-10-16 6 views
4

Я использую Javamail для аутентификации в gmail imap-сервере и получения заголовков сообщений для полного почтового ящика по одному и индекса локально. Для почтовых ящиков с небольшим количеством сообщений это работает нормально. Для почтовых ящиков с сообщениями более 10k в общем случае соединение javamail imap удаляется (возможно, сервером). Следует отметить, что эта продолжительность является случайной.Javamail IMAP-соединение с Gmail падает после случайной продолжительности

Поскольку я постоянно получаю заголовки сообщений один за другим, нет времени, когда соединение простаивает долго, поэтому он не может быть таймаутом.

------------------------------ КОД --------------- -----------------

IMAPSSLStore imapSslStore = connectToImap("imap.googlemail.com", 993, email, oauthToken, oauthTokenSecret, getMyConsumer(), true); 
System.out.println("Successfully authenticated to IMAP.\n"); 
Folder inbox = imapSslStore.getFolder("[Gmail]/All Mail"); 
inbox.open(Folder.READ_ONLY); 

Message messages[] = inbox.getMessages(); 

for(Message message:messages) { 
    System.out.println(message); 
    System.out.println("MSG NO:"+message.getMessageNumber()); 
    System.out.println("FROM:"+message.getFrom().toString()); 
} 

-------------------------- -----КОД--------------------------------------------

Исключение трассировки:

[java] javax.mail.FolderClosedException: * BYE JavaMail Exception: java.io.IOException: **Connection dropped by server?** 

[java] at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:194) 
[java] at org.apache.tools.ant.taskdefs.Java.run(Java.java:747) 
[java] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:201) 
[java] at org.apache.tools.ant.taskdefs.Java.execute(Java.java:104) 
[java] at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[java] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[java] at java.lang.reflect.Method.invoke(Method.java:597) 
[java] at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105) 
[java] at org.apache.tools.ant.Task.perform(Task.java:348) 
[java] at org.apache.tools.ant.Target.execute(Target.java:357) 
[java] at org.apache.tools.ant.Target.performTasks(Target.java:385) 
[java] at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329) 
[java] at org.apache.tools.ant.Project.executeTarget(Project.java:1298) 
[java] at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41) 
[java] at org.apache.tools.ant.Project.executeTargets(Project.java:1181) 
[java] at org.apache.tools.ant.Main.runBuild(Main.java:698) 
[java] at org.apache.tools.ant.Main.startAnt(Main.java:199) 
[java] at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257) 
[java] at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104) 
[java] Caused by: javax.mail.FolderClosedException: * BYE JavaMail Exception: java.io.IOException: Connection dropped by server? 
[java] at com.sun.mail.imap.IMAPMessage.loadEnvelope(IMAPMessage.java:1198) 
[java] at com.sun.mail.imap.IMAPMessage.getFrom(IMAPMessage.java:233) 
[java] at com.google.code.samples.xoauth.XoauthAuthenticator.main(XoauthAuthenticator.java:209) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[java] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[java] at java.lang.reflect.Method.invoke(Method.java:597) 
[java] at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217) 
[java] at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152) 
[java] ... 20 more 
[java] --- Nested Exception --- 
[java] javax.mail.FolderClosedException: * BYE JavaMail Exception: java.io.IOException: Connection dropped by server? 
[java] at com.sun.mail.imap.IMAPMessage.loadEnvelope(IMAPMessage.java:1198) 
[java] at com.sun.mail.imap.IMAPMessage.getFrom(IMAPMessage.java:233) 
[java] at com.google.code.samples.xoauth.XoauthAuthenticator.main(XoauthAuthenticator.java:209) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[java] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[java] at java.lang.reflect.Method.invoke(Method.java:597) 
[java] at org.apache.tools.ant.taskdefs.ExecuteJava.run(ExecuteJava.java:217) 
[java] at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:152) 
[java] at org.apache.tools.ant.taskdefs.Java.run(Java.java:747) 
[java] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:201) 
[java] at org.apache.tools.ant.taskdefs.Java.execute(Java.java:104) 
[java] at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
[java] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
[java] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
[java] at java.lang.reflect.Method.invoke(Method.java:597) 
[java] at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105) 
[java] at org.apache.tools.ant.Task.perform(Task.java:348) 
[java] at org.apache.tools.ant.Target.execute(Target.java:357) 
[java] at org.apache.tools.ant.Target.performTasks(Target.java:385) 
[java] at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329) 
[java] at org.apache.tools.ant.Project.executeTarget(Project.java:1298) 
[java] at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41) 
[java] at org.apache.tools.ant.Project.executeTargets(Project.java:1181) 
[java] at org.apache.tools.ant.Main.runBuild(Main.java:698) 
[java] at org.apache.tools.ant.Main.startAnt(Main.java:199) 
[java] at org.apache.tools.ant.launch.Launcher.run(Launcher.java:257) 
[java] at org.apache.tools.ant.launch.Launcher.main(Launcher.java:104) 

Я использую автономную версию JavaMail (1.4.3) Я изо всех сил, чтобы исправить это на некоторое время теперь. Любая помощь приветствуется.

+0

Не могли бы вы решить эту проблему? Я тоже планирую использовать это ... – Theo

+0

Это, к сожалению, проблема. мы просто должны повторить попытку после Google BYE. –

+0

@SaqibAli Вы попробовали мое решение? –

ответ

4

Вам нужно поймать FolderClosedException, а затем попробуйте снова подключиться. Я столкнулся с этой проблемой и решил ее использовать по следующему коду:

catch (FolderClosedException ex) { 
         ex.printStackTrace(); 
         ConnectPop3(Username, Password); 
         if (!folder.isOpen()) { 
          folder.open(Folder.READ_ONLY); 
          messages = folder.getMessages(); 
         } 
        } 
Смежные вопросы