我们正在考虑迁移到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时,我从代码中复制了它们并将它们粘贴到登录屏幕中-一切都很好。
我究竟做错了什么?