我尝试使用javax.mail尝试从IMAP文件夹中读取邮件,但是在获取fetchig之后,我收到以下异常:
* 20 FETCH ()
DEBUG IMAPS: ignoring bad response, THROW:
com.sun.mail.iap.ParsingException: error in FETCH parsing, unrecognized item at index 12, starts with ")
at com.sun.mail.imap.protocol.FetchResponse.parse(FetchResponse.java:219)
at com.sun.mail.imap.protocol.FetchResponse.<init>(FetchResponse.java:96)
at com.sun.mail.imap.protocol.IMAPProtocol.readResponse(IMAPProtocol.java:392)
at com.sun.mail.iap.Protocol.command(Protocol.java:354)
at com.sun.mail.imap.protocol.IMAPProtocol.fetch(IMAPProtocol.java:2113)
at com.sun.mail.imap.protocol.IMAPProtocol.fetch(IMAPProtocol.java:2094)
at com.sun.mail.imap.IMAPFolder.fetch(IMAPFolder.java:1253)
at app.mail.imap.ImapClient.synchronizeLocalData(ImapClient.java:563)
at app.mail.imap.ImapClient.lambda$6(ImapClient.java:351)
at java.lang.Thread.run(Thread.java:745)
* BYE Internal error occurred. Refer to server log for more information. [2016-11-03 21:20:44]
这是我用来读取消息的代码(会话,商店和文件夹已经打开):
final Message[] messages = imapFolder.getMessagesByUID(1, IMAPFolder.LASTUID);
final FetchProfile fp = new FetchProfile();
fp.add(FetchProfile.Item.ENVELOPE);
fp.add(FetchProfile.Item.FLAGS);
imapFolder.fetch(messages, fp);
for (final Message msg : messages)
{
final long uid = imapFolder.getUID(msg);
final String subject = MimeUtility.decodeText(msg.getSubject());
final Date date = msg.getReceivedDate();
info("MESSAGE: {} -> {} on {}", uid, subject, date);
}
它似乎只在非常具体的消息上发生,并且只在获取比消息UID更多的信息时才会发生(如果我只读取uid然后代码可以工作)。
据我所知,许多IMAP服务器实现缺少IMAP协议的许多功能。请记住,从IMAP文件夹中获取和读取邮件的最安全,最可靠的方法是什么?
javax.mail版本:1.5.3(由wildfly app server 10.0.1.Final提供)。
答案 0 :(得分:0)
感谢您的帮助。看来它确实是IMAP服务器错误。当我在网络客户端打开消息时,我得到:
Connection error (#022).
此外,KMail不会下载该文件夹的消息(我也打赌其他客户)。