【发布时间】:2020-05-01 06:33:05
【问题描述】:
我们正在考虑迁移到 O365;但是,我们开发的软件使用我们当前的 Exchange 服务器向外部用户发送电子邮件,并在发生错误时发送到支持箱。
我一直在对此进行测试,以确保我们现有的代码将继续与 O365 一起使用,但到目前为止,我还不是很成功。
我尝试过使用 .Net 的 SmtpClient 和 MailKit 的 SmtpClient,但似乎都没有。我不断收到错误(这是来自 MailKit 的错误——.Net 错误类似)
“AuthenticationInvalidCredentials:5.7.3 身份验证不成功[*.prod.exchangelabs.com]”
我可以使用我在代码中拥有的凭据登录 OWA——因此我知道这些凭据是有效的。不能通过 O356 发送电子邮件吗?是否需要在 Exchange 中进行任何特殊配置才能实现这一点?
这是我迄今为止尝试过的:
MailKit
var msg = new MimeMessage();
msg.From.Add(new MailboxAddress("Support","support@mydomain.com"));
msg.To.Add(new MailboxAddress("Me","me@mydomain.com"));
msg.To.Add(new MailboxAddress("External User","euser@externaldomain.com"));
msg.Subject = "Test";
msg.Body = new TextPart("plain"){
Text = "Here is a message for you"
};
using(var client = new SmtpClient()){
client.ServerCertificateValidationCallback = (s,c,h,e) => true;
client.AuthenticationMechanisms.Remove("XOAUTH2"); //Not sure what this does. Have tried with and without
client.Connect("smtp.office365.com", 587, MailKit.Security.SecureSocketOptions.StartTls);
client.Authenticate(new NetworkCredential("support@mydomain.com", "supportPwd"));
client.Send(msg);
client.Disconnect(true);
}
.Net SmtpClient 代码看起来与 MailKit 代码非常相似。
- 有没有办法通过 O365 与许可用户一起发送? (上面的代码)
- 是否需要在 Exchange 中或许可用户上进行任何特殊设置才能使其正常工作? (如果 1 的答案是肯定的)
- 是否可以通过凭据用户拥有“代理发送”权限的共享邮箱发送电子邮件?
更新
我仍然收到相同的错误消息。我们确实为我们的域用户启用了 MFA。但是,我们有一项政策,当用户从受信任的位置(我们组织的 IP)登录时,他们不需要 MFA。我还将我们的 IP 列为受信任的 IP。在我看来,MFA 不应该是这里的问题。
我知道凭据是正确的。我从代码中复制它们并在登录 M365 时将它们粘贴到登录屏幕中——我很好地进入了。
我做错了什么?
【问题讨论】:
标签: c# .net smtp office365 mailkit