Kun*_*uni 9 c# exchangewebservices
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();
}
Run Code Online (Sandbox Code Playgroud)
如何使用共享邮箱发送电子邮件而不是硬编码电子邮件地址和密码?我使用的电子邮件地址是不符合当前密码安全标准的服务帐户.正是由于这个原因,他们正在将部门电子邮件更改为共享邮箱.
我正在使用Windows身份验证来验证Active Directory中的用户.
Gle*_*les 10
如果您想继续使用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);
Run Code Online (Sandbox Code Playgroud)
允许您摆脱服务帐户的更好方法是使用新的REST API https://msdn.microsoft.com/en-us/office/office365/api/mail-rest-operations然后创建一个只拥有发送电子邮件权利并利用证书身份验证的应用程序https://msdn.microsoft.com/en-us/office/office365/howto/building-service-apps-in-office-365.这应该允许您摆脱服务帐户的任何许可证要求,并且还提供更安全的应用程序,因为您不再拥有硬编码的信用卡,并且您的应用程序只能访问它需要执行的操作而无需其他操作.
| 归档时间: |
|
| 查看次数: |
4976 次 |
| 最近记录: |