vb.net - EWS 连接到 Office365 失败 - 401 未经授权

标签 vb.net office365 ems

我需要制作一个 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) 未经授权”而停止。

提出问题的说明指出,我应该包含指向我已经找到的内容以及它不起作用的原因的链接,但我的 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-management-api-retriving -来自 Office365-exchange-server 的电子邮件

这是我的代码:

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

与 Outlook 中的测试电子邮件自动配置相比,我已确认自动发现正确查找服务器。

AutoConfig

有趣的旁注 - 在我的公司迁移到 Office 365 后,我注意到我有两个新的 SMTP 邮件地址。如果我打开自己的 Outlook 属性,我会看到以下内容:

Props

这意味着有人现在可以通过旧地址 john.doe@mycorp.com 向我发送邮件,现在也可以通过 doejohn@mycorp.mail.onmicrosoft.com 向我发送邮件。新地址基于我的域用户代码。我通过 Gmail 帐户测试了 microsoft 帐户,它可以正常工作。

总而言之,这是我的问题: 1. 当我尝试读取收件箱时,为什么会收到 (401) 未经授权的错误? 2. Office 365 是否希望我使用我的域帐户或邮箱名称作为用户凭据? 3. 在 WebCredentials 语句的域部分中,我是使用我公司的 mycorp.com 还是使用 Office 365 的域 Outlook.office365.com?

如果您已经读到这里,非常感谢!

最佳答案

我找到了上述问题的答案,所以我会在这里分享,以防有人需要。问题归结于我的 IT 组织添加的安全协议(protocol),由于最近对我们公司的网络钓鱼攻击,这些协议(protocol)没有记录在案。

第一个线索是 IT 部门表示,如果我想在我的个人 4G 设备(例如智能手机或 iPad)上检查公司电子邮件,我还必须安装 Microsoft InTune,以实现与 O365 邮件服务器的 MFA 连接。由于我不知道如何将 InTune 集成到我的 .Net 应用程序中,因此我不得不寻找另一个答案。

我请求并获得批准将我的功能邮箱从 O​​365 移动到此应用程序的本地 Exchange 服务器。这解决了身份验证问题。

关于vb.net - EWS 连接到 Office365 失败 - 401 未经授权,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45725630/

相关文章:

c# - AMAZON Api 认证错误

asp.net - AJAX - TagPrefix 未注册

go - 使用 golang 库 unioffice 填写 docx 中的表单字段

javascript - 使用 Word JavaScript API 添加超链接

delphi - 使用动态数组时 Linux 版 RAD 服务器上的内存泄漏

jms - Tibco-Ems 故障转移问题

vb.net - 某些音频文件会播放,但其他音频文件不会播放

c# - .NET 如何检查 Windows 进程是否作为 "App"或 "Background application"运行

连接到 TFS 的 Excel TFS 加载项崩溃

spring - 使用 Spring + SSL 连接到 EMS JMS 队列