我需要制作一个VB .net工具来阅读电子邮件并保存附件。我的公司最近从内部部署Exchange迁移到Office 365.我已经阅读了2天的EWS教程,并且正在搜索StackOverflow,但无法通过授权访问O365邮箱的最基本步骤。
我从这篇文章中获取了原始代码:htp://www.c-sharpcorner.com/UploadFile/jj12345678910/reading-email-and-attachment-from-microsoft-exchange-server/。我使用Telerik转换器将其转换为VB时遇到了一些麻烦,但我认为我说得对。每次我尝试使用FindItemsResults方法时,它都会以“(401)Unauthorized”停止。
询问问题的说明说明我应该包含我已经找到的链接以及为什么它不起作用,但我的SO声誉只允许我2个链接。这是我尝试过的:
我在阅读本页后尝试了所有可能的用户代码和域名组合:htps://stackoverflow.com/questions/10107872/ews-connections-issues-401-unauthorized
我正在尝试阅读自己的邮箱,所以这个没有帮助:htps://stackoverflow.com/questions/43346498/401-unauthorized-access-when-using-ews-to-connect-to-mailbox
我的连接看起来与此页面上的连接相同,但在我的项目中使用它并未遇到与以前相同的未经授权的错误:htps://stackoverflow.com/questions/29009295/ews-managed-api-retrieving -e邮件从 - office365交换服务器
这是我的代码:
Public Class Form1
Public Exchange As ExchangeService
Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
lstMsg.Clear()
lstMsg.View = View.Details
lstMsg.Columns.Add("Date", 150)
lstMsg.Columns.Add("From", 250)
lstMsg.Columns.Add("Subject", 400)
lstMsg.Columns.Add("Has Attachment", 50)
lstMsg.Columns.Add("Id", 100)
lstMsg.FullRowSelect = True
End Sub
Public Sub ConnectToExchangeServer()
Me.lblMsg.Text = "Connecting to Exchange Server"
lblMsg.Refresh()
Try
'Exchange = New ExchangeService(ExchangeVersion.Exchange2013)
Exchange = New ExchangeService()
Exchange.TraceEnabled = True
'Exchange.UseDefaultCredentials = True
Exchange.Credentials = New WebCredentials("DoeJohn", "mypasswd", "mycorp.com")
'Exchange.AutodiscoverUrl("DoeJohn@mycorp.mail.onmicrosoft.com", AddressOf MyRedirectionURLValidationCallback)
'Exchange.AutodiscoverUrl("John.Doe@mycorp.com", AddressOf MyRedirectionURLValidationCallback)
Exchange.Url = New System.Uri("https://outlook.office365.com/ews/exchange.asmx")
lblMsg.Text = "Connected to Exchange Server"
lblMsg.Refresh()
Catch ex As Exception
MsgBox("Fatal Error in Connect: " & ex.Message)
End
End Try
End Sub
Public Function MyRedirectionURLValidationCallback(RedirectionURL As String) As Boolean
Dim Result As Boolean = False
Dim RedirectionURI As Uri = New Uri(RedirectionURL)
If RedirectionURI.Scheme = "https" Then
Return True
End If
Return False
End Function
Private Sub btnRead_Click(sender As Object, e As EventArgs) Handles btnRead.Click
Call ConnectToExchangeServer()
Dim ts As TimeSpan = New TimeSpan(0, -1, 0, 0)
Dim MyDate As DateTime = DateTime.Now.Add(ts)
Dim MyFilter As SearchFilter.IsGreaterThanOrEqualTo = New SearchFilter.IsGreaterThanOrEqualTo(ItemSchema.DateTimeReceived, MyDate)
If Exchange IsNot Nothing Then
Dim FindResults As FindItemsResults(Of Item) =
Exchange.FindItems(WellKnownFolderName.Inbox, MyFilter, New ItemView(50))
Dim NewRow As ListViewItem
For Each MyItem As Item In FindResults
Dim Message As EmailMessage = EmailMessage.Bind(Exchange, MyItem.Id)
NewRow = New ListViewItem(Message.DateTimeReceived.ToString())
NewRow.SubItems.Add(Message.From.Name.ToString())
NewRow.SubItems.Add(Message.Subject)
NewRow.SubItems.Add(Message.HasAttachments.ToString())
NewRow.SubItems.Add(Message.Id.ToString())
lstMsg.Items.Add(NewRow)
Next
Else
End If
End Sub
我已确认AutoDiscover正确查找服务器,与Outlook中的测试电子邮件自动配置相比。
一个有趣的旁注 - 在我的公司迁移到Office 365之后,我注意到我有两个新的SMTP邮件地址。如果我打开自己的Outlook属性,我会看到:
这意味着有人可以在旧地址john.doe@mycorp.com以及现在的doejohn@mycorp.mail.onmicrosoft.com向我发送邮件。新地址基于我的域用户代码。我从一个Gmail帐户测试了微软的一个,它可以工作。
总结一下,这是我的问题: 1.当我尝试阅读收件箱时,为什么会收到(401)未经授权的错误? 2. Office 365是否希望我使用我的域帐户或我的邮箱名称来获取用户凭据? 3.在WebCredentials声明的域部分中,我是使用我公司的mycorp.com还是使用Office 365的域outlook.office365.com?
如果您已经阅读过这篇文章,非常感谢!
答案 0 :(得分:0)
我找到了上述问题的答案,所以如果有人需要,我会在这里分享。问题在于我的IT组织添加的安全协议由于最近对我们公司的网络钓鱼攻击而没有记录。
第一个线索是,IT表示如果我想在智能手机或ipad等个人4G设备上查看公司电子邮件,我还必须安装Microsoft InTune for MFA连接到O365邮件服务器。由于我不知道如何将InTune集成到我的.Net应用程序中,我不得不寻找另一个答案。
我已请求并获准将我的功能邮箱从O365移至此应用的内部部署Exchange服务器。这解决了身份验证问题。