Mailkit 身份验证失败
Mailkit Authentication Failure
我的问题:
相同的代码在一个实例中工作正常,但无法在项目的另一个实例中使用相同的 username/password 进行身份验证。
我的代码:
static NetworkCredential _emailLoginCredentials;
_emailLoginCredentials = new NetworkCredential(_accountName, _accountPassword, _accountDomain);
using (var client = new ImapClient(new ProtocolLogger("C://Temp//Logs//imap1.log")))
{
var credentials = _emailLoginCredentials;
var uri = new Uri(_emailServer);
string serverReply = String.Empty;
client.Timeout = _imapClientTimeOut;
client.Connect(uri);
client.AuthenticationMechanisms.Remove("XOAUTH2");
client.Authenticate(credentials);
client.Inbox.Open(FolderAccess.ReadWrite);
}
错误:
Connected to imap://mail.company.com:143/?starttls=when-available
S: * OK The Microsoft Exchange IMAP4 service is ready.
C: A00000000 CAPABILITY
S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=NTLM AUTH=GSSAPI AUTH=PLAIN UIDPLUS CHILDREN IDLE NAMESPACE LITERAL+
S: A00000000 OK CAPABILITY completed.
C: A00000001 AUTHENTICATE PLAIN
S: +
C: ZljbAY3hDYXJhdHNkZXYAQ2FyYXRzMTIz
S: A00000001 NO AUTHENTICATE failed.
C: A00000002 LOGIN username Password
S: A00000002 NO LOGIN failed.
来自工作项目的日志(相同代码):
Connected to imap://mail.company.com:143/?starttls=when-available
S: * OK The Microsoft Exchange IMAP4 service is ready.
C: A00000000 CAPABILITY
S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=NTLM AUTH=GSSAPI AUTH=PLAIN UIDPLUS CHILDREN IDLE NAMESPACE LITERAL+
S: A00000000 OK CAPABILITY completed.
C: A00000001 AUTHENTICATE PLAIN
S: +
C: AN4FyYXRzZGV2AENhcmF0czEyMw==
S: A00000001 OK AUTHENTICATE completed.
为了排除故障,我什至在两者中都硬编码了用户名和密码。然而,结果仍然是一样的——一个工作,另一个不工作。
好吧,在项目设置等方面存在一些差异。例如,在非工作项目中,我在 Mutex 中使用上述身份验证代码。另外,整个方法是protected override async Task Process(TaskMessage message)
找到这个 post 但它是由与我的情况无关的 NTLM 引起的。
Mailkit Authenticate to Imap fails
普通身份验证包含两个或三个字符串:"I wish to log in as x, I'm actually y, and my password is z"。两种常见情况是 x=y 和 x not specified。极少数情况下,y 是超级特权管理员用户,可以以其他身份登录。
在您的工作案例中,x 为空,y 为 xCaratsdev。在您的错误情况下,x 是 gicnt。您的密码在这两种情况下都是相同的(它在 base64 blob 中)。你的下一个工作是找出那个 gicnt 的来源。但首先,更改密码。
我的问题:
相同的代码在一个实例中工作正常,但无法在项目的另一个实例中使用相同的 username/password 进行身份验证。
我的代码:
static NetworkCredential _emailLoginCredentials;
_emailLoginCredentials = new NetworkCredential(_accountName, _accountPassword, _accountDomain);
using (var client = new ImapClient(new ProtocolLogger("C://Temp//Logs//imap1.log")))
{
var credentials = _emailLoginCredentials;
var uri = new Uri(_emailServer);
string serverReply = String.Empty;
client.Timeout = _imapClientTimeOut;
client.Connect(uri);
client.AuthenticationMechanisms.Remove("XOAUTH2");
client.Authenticate(credentials);
client.Inbox.Open(FolderAccess.ReadWrite);
}
错误:
Connected to imap://mail.company.com:143/?starttls=when-available
S: * OK The Microsoft Exchange IMAP4 service is ready.
C: A00000000 CAPABILITY
S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=NTLM AUTH=GSSAPI AUTH=PLAIN UIDPLUS CHILDREN IDLE NAMESPACE LITERAL+
S: A00000000 OK CAPABILITY completed.
C: A00000001 AUTHENTICATE PLAIN
S: +
C: ZljbAY3hDYXJhdHNkZXYAQ2FyYXRzMTIz
S: A00000001 NO AUTHENTICATE failed.
C: A00000002 LOGIN username Password
S: A00000002 NO LOGIN failed.
来自工作项目的日志(相同代码):
Connected to imap://mail.company.com:143/?starttls=when-available
S: * OK The Microsoft Exchange IMAP4 service is ready.
C: A00000000 CAPABILITY
S: * CAPABILITY IMAP4 IMAP4rev1 AUTH=NTLM AUTH=GSSAPI AUTH=PLAIN UIDPLUS CHILDREN IDLE NAMESPACE LITERAL+
S: A00000000 OK CAPABILITY completed.
C: A00000001 AUTHENTICATE PLAIN
S: +
C: AN4FyYXRzZGV2AENhcmF0czEyMw==
S: A00000001 OK AUTHENTICATE completed.
为了排除故障,我什至在两者中都硬编码了用户名和密码。然而,结果仍然是一样的——一个工作,另一个不工作。
好吧,在项目设置等方面存在一些差异。例如,在非工作项目中,我在 Mutex 中使用上述身份验证代码。另外,整个方法是protected override async Task Process(TaskMessage message)
找到这个 post 但它是由与我的情况无关的 NTLM 引起的。
Mailkit Authenticate to Imap fails
普通身份验证包含两个或三个字符串:"I wish to log in as x, I'm actually y, and my password is z"。两种常见情况是 x=y 和 x not specified。极少数情况下,y 是超级特权管理员用户,可以以其他身份登录。
在您的工作案例中,x 为空,y 为 xCaratsdev。在您的错误情况下,x 是 gicnt。您的密码在这两种情况下都是相同的(它在 base64 blob 中)。你的下一个工作是找出那个 gicnt 的来源。但首先,更改密码。