11

我正在从 emailServer 读取电子邮件并将它们保存在数据库中。我正在使用以下代码从电子邮件服务器上的文件夹(“INBOX”)中读取消息并检索与它们对应的消息,但我得到了

"java.lang.ArrayIndexOutOfBoundsException: message number (621) out of bounds (620)
at com.sun.mail.imap.MessageCache.getMessage(MessageCache.java:123)
at com.sun.mail.imap.MessageCache.getMessageBySeqnum(MessageCache.java:153)
at com.sun.mail.imap.IMAPFolder.getMessageBySeqNumber(IMAPFolder.java:2795)
at com.sun.mail.imap.IMAPFolder.getMessagesByUID(IMAPFolder.java:1924)"

我正在使用 javax.mail.1.4.4,这个问题主要出现在收件箱被淹没时。

使用的代码:

folder = store.getFolder("INBOX");

folder.open(Folder.READ_WRITE);
// messageUID is uid of last message I saved in DB

 Message messages[] = ((UIDFolder) folder).getMessagesByUID(messageUID + 1, UIDFolder.LASTUID);

我做了一些研究,发现 messagecache 一打开就为文件夹设置,假设它设置为 520(文件夹大小)。而如果在设置消息缓存后有任何消息到达,则在最后一个消息序列中,num 超出消息缓存的总大小,并引发异常。

谁能让我知道如何获取文件夹中最后一条消息的 UId 的绝对值或如何获取文件夹锁定,以便在设置缓存后,文件夹不会更新文件夹的大小。

4

2 回答 2

6

有趣的问题!

首先,我认为这是 javax 邮件中的一个错误。可能应该在getMessageBySeqNumber()中调用checkRange( ) ,或者只是一个带有向量大小的Math.min() 。

无论如何,问题在于代码会转到服务器以获取最新的消息计数,但从不更新本地 messageCache。这意味着 messageCache 与该方法相比具有过时的数据,但该方法仍假定它是最新的……正如您所看到的那样,这很有趣。

现在,如何避免它直到它被修复?

不幸的是,我认为您遇到了一些可怕的解决方法,例如:

folder = store.getFolder("INBOX");

folder.open(Folder.READ_WRITE);
// messageUID is uid of last message I saved in DB

/* I apologize for all of the kittens that this code is about to kill */
boolean getMessagesWorked = false;
do {
  try {
    Message messages[] = ((UIDFolder) folder).getMessagesByUID(messageUID + 1, UIDFolder.LASTUID);
    getMessagesWorked = true;
   } catch (ArrayIndexOutOfBoundsException e) {
     /* Doing this should force the internal messagesCache to get updated
      * Unfortunately, this is also somewhat racy, depending on just how
      * hard the mail folder is being hit */
      try {
       folder.getMessage(folder.getMessageCount());
      } catch (ArrayIndexOutOfBoundsException e) {
        /* There really isn't much you can do here, except try again.
         * the good news is that this should hardly ever happen!!
         * Good in this case is a relative term! */
      }
   }
} while (! getMessagesWorked);
于 2013-11-13T23:27:46.453 回答
0

这可能是这个 Javamail 错误:

https://java.net/projects/javamail/lists/issues/archive/2010-09/message/1

于 2014-10-21T12:04:43.853 回答