0

我正在为 Outlook 开发 VSTO 加载项,现在我收到一封退回电子邮件,其中包含邮件 ID。如何在 VSTO 程序中从这个消息 ID 跟踪原始电子邮件?

4

2 回答 2

0

正如 Eugene 提到的,您需要根据 PR_INTERNET_MESSAGE_ID 属性搜索已发送的消息。没有理由使用Items.Restrict或什Find/FindNext至 - 因为您期待一个匹配(除非您的邮箱确实有问题),Items.Find所以您只需要一个呼叫。

还要记住,在缓存的 Exchange 模式PR_INTERNET_MESSAGE_ID中不会对“已发送邮件”文件夹中的项目设置。要解决这个问题,您需要以在线模式打开“已发送邮件”文件夹(您可以使用 C++/Delphi 中的扩展 MAPI 或任何语言的Redemption来完成此操作)。

于 2020-05-19T00:28:08.507 回答
0

您可以搜索PR_INTERNET_MESSAGE_ID属性值。属性的 DASL 名称是http://schemas.microsoft.com/mapi/proptag/0x1035001F

使用类的Find/FindNextRestrict方法Items。该Restrict方法是使用Find方法或FindNext方法迭代集合中的特定项目的替代方法。如果项目数量很少,FindorFindNext方法比过滤更快。如果集合中有大量项目,则该Restrict方法会明显更快,特别是如果预计只能找到大型集合中的少数项目。

但是,如果您需要从多个文件夹中查找项目,我建议您改用该AdvancedSearch方法:

Public m_SearchComplete As Boolean  

Private Sub Application_AdvancedSearchComplete(ByVal SearchObject As Search)  
    If SearchObject.Tag = "MySearch" Then  
        m_SearchComplete = True  
    End If  
End Sub  

Sub TestSearchForMultipleFolders()  
    Dim Scope As String  
    Dim Filter As String  
    Dim MySearch As Outlook.Search  
    Dim MyTable As Outlook.Table  
    Dim nextRow As Outlook.Row  
    m_SearchComplete = False  
    'Establish scope for multiple folders  
    Scope = "'" & Application.Session.GetDefaultFolder( _  
    olFolderInbox).FolderPath _  
    & "','" & Application.Session.GetDefaultFolder( _  
    olFolderSentMail).FolderPath & "'"  
    'Establish filter  
    If Application.Session.DefaultStore.IsInstantSearchEnabled Then  
        Filter = Chr(34) & "http://schemas.microsoft.com/mapi/proptag/0x1035001F" _  
        & Chr(34) & " ci_phrasematch 'MesssageID'"  
    Else  
        Filter = Chr(34) & "http://schemas.microsoft.com/mapi/proptag/0x1035001F" _  
        & Chr(34) & " like '%MessageID%'"  
    End If  
    Set MySearch = Application.AdvancedSearch( _  
    Scope, Filter, True, "MySearch")  
    While m_SearchComplete <> True  
        DoEvents  
    Wend  
    Set MyTable = MySearch.GetTable  
    Do Until MyTable.EndOfTable  
        Set nextRow = MyTable.GetNextRow()  
        Debug.Print nextRow("Subject")  
    Loop  
End Sub
于 2020-05-18T11:20:43.460 回答