未标记的FETCH响应中的MailKit Fetch语法错误。意外的标记:'\\ n'

时间:2017-11-01 12:51:09

标签: c# mailkit

我已经看到了几个关于此的问题,但是它们似乎都没有与我遇到的问题相匹配,因此产生了这些问题。

我有一个邮箱(这是第一个也是唯一一个我看到此问题的邮箱),针对Domino服务器运行。当它尝试FETCH此帐户的收件箱时,它会读取

foreach (var summary in client.Inbox.Fetch(0, -1, Items).Where(x => 
    (x.Flags & MessageFlags.Deleted) != MessageFlags.Deleted &&
    (x.Flags & MessageFlags.Seen) != MessageFlags.Seen))
    {
        //Do something...
    }

我的imap协议日志中的最后一项是:

S:  FLAGS (\Seen))      
S: * 8303 FETCH (UID 8303 ENVELOPE ({..MASKED..}) BODY[HEADER.FIELDS (REFERENCES)] {4}      
S: 
S: 
S:  FLAGS (\Seen))

此日志中没有FETCH COMPLETE,似乎有时日志比其他日志更大(获取更多电子邮件)。异常始终是相同的,未展开的令牌\ n。

关于原子令牌异常的更新:

{"Syntax error in ENVELOPE. Unexpected token: [atom: <user@domain.orguser]"}


S:  FLAGS (\Seen))
S: * 19607 FETCH (UID 19607 ENVELOPE ("Wed, 8 Nov 2014 13:50:09 +0100" "Re: LDAP Filter" (("DisplayName1" NIL "dn1" "domain2.invalid")) (("DisplayName1" NIL "dn1" "domain2.invalid")) (("DisplayName1" NIL "dn1" "domain2.invalid")) (("DisplayName4" NIL "dn4" "domain1.invalid")("DisplayName3" NIL "dn3" "domain3.invalid")) (("DisplayName2" NIL "dn2" "domain2.invalid")("user@domain.org" NIL "user" "domain.org> "ss@domain.org" <user@domain.orguser")) NIL "<OF4C7FF16B.1B0A6826-ONC1257D6B.003FBF81-C1257D6B.00400501@LocalDomain>" "<OF31482F53.2CA9A4AC-ONC1257D6B.004080EE-C1257D6B.00410453@LocalDomain>") BODY[HEADER.FIELDS (REFERENCES SUBJECT)] {235}
S: Subject: Re: LDAP Filter
S: References: <3A5893A9FA8E964D862DAA1FA2B5E9EA1BCD89@OESTMB701.domain1.invalid>
S:  <3A5893A9FA8E964D862DAA1FA2B5E9EA1C1A45@OESTMB701.domain1.invalid>
S:  <OF4C7FF16B.1B0A6826-ONC1257D6B.003FBF81-C1257D6B.00400501@LocalDomain>

1 个答案:

答案 0 :(得分:1)

它说它遇到了意外的换行符。问题是可能是,标题解析器不会消耗空标题blob的所有4个字节(它可能只消耗第一个空行)。

解决方法可能是请求一个存在的标题以及REFERENCES标题(可能是SUBJECT)。

var headers = new HashSet<string> ();
headers.Add ("REFERENCES");
headers.Add ("SUBJECT");

var items = folder.Fetch (0, -1, summaryItemFlags, headers);