IT部门正在从创建服务帐户转向共享邮箱。我们所有的部门电子邮件帐户都将转换为共享邮箱。到目前为止,我一直使用EWS使用以下代码从我们的网络应用程序向收件人发送电子邮件:
ExchangeService service = new ExchangeService();
service = new ExchangeService(ExchangeVersion.Exchange2013_SP1)
{
Credentials = new NetworkCredential("dept_email@example.com", "Password1"),
Url = new Uri("https://outlook.office365.com/EWS/Exchange.asmx")
};
email = new EmailMessage(service);
email.Body = new MessageBody(BodyType.HTML, Message.ToString());
email.ToRecipients.Add(Recipient.email);
email.SendAndSaveCopy();
}
如何使用共享邮箱发送电子邮件而不是硬编码电子邮件地址和密码?我使用的电子邮件地址是不符合当前密码安全标准的服务帐户。正是由于这个原因,他们正在将部门电子邮件更改为共享邮箱。
我正在使用Windows身份验证来验证Active Directory中的用户。
答案 0 :(得分:6)
如果您想继续使用EWS,您仍然可能需要一个服务帐户才能使用共享邮箱(除非您的应用程序可以模拟在共享邮箱上具有SendAS权限的用户),例如您授予服务帐户SendAs权限您要发送的共享邮箱,然后将发件人地址和已发送邮件文件夹设置为共享邮箱的文件夹(如果您想要保存在共享邮箱已发送邮件文件夹中的邮件副本,则该邮箱)。例如
email.From = new EmailAddress("smtpaddress@domain.com");
Mailbox SharedMailbox = new Mailbox("smtpaddress@domain.com");
FolderId SharedMailboxSendItems = new FolderId(WellKnownFolderName.SentItems, SharedMailbox);
email.SendAndSaveCopy(SharedMailboxSendItems);
允许您摆脱服务帐户的更好方法是使用新的REST API https://msdn.microsoft.com/en-us/office/office365/api/mail-rest-operations,然后创建一个只有权发送电子邮件并利用证书身份验证的应用程序{{3 }}。这应该允许您摆脱服务帐户的任何许可证要求,并且还提供更安全的应用程序,因为您不再拥有硬编码的信用卡,并且您的应用程序只能访问它需要执行的操作而无需其他操作。