首页 > 解决方案 > C# 使用 Microsoft.Exchange.WebServices EWS 在指定日期之后获取邮件

问题描述

我正在使用 EWS 下载邮件。由于邮箱很大,我想用查询字符串过滤邮件。Received:20/11/2019我找到了一种仅使用但下载指定日期的邮件的方法

  1. 这不是从该日期返回所有邮件(为什么 - 似乎只有带有附件的未读邮件是结果的一部分)
  2. 我想收到 2019 年 11 月 20 日及以后的所有邮件

这是我的代码:

    Microsoft.Exchange.WebServices.Data.ExchangeService exchange = new Microsoft.Exchange.WebServices.Data.ExchangeService(Microsoft.Exchange.WebServices.Data.ExchangeVersion.Exchange2013);
    exchange.Credentials = new Microsoft.Exchange.WebServices.Data.WebCredentials("User", "********", "Domain");
    exchange.AutodiscoverUrl("Name@domain.com");
    string QString = "Recieved:20/11/2019";

    if (exchange != null)
    {
        Microsoft.Exchange.WebServices.Data.FindItemsResults<Microsoft.Exchange.WebServices.Data.Item> Results = exchange.FindItems(Microsoft.Exchange.WebServices.Data.WellKnownFolderName.Inbox, QString, new Microsoft.Exchange.WebServices.Data.ItemView(100));

        foreach(Microsoft.Exchange.WebServices.Data.Item MI in Results)
        {
            /*Print subject to command window*/
            System.Console.WriteLine(MI.Subject);
        }
    }

我在这里找到了答案,但它的 PHP 和我不是很熟练: Getting emails after a specific date with php-ews (Exchange Web Services)

标签: c#query-stringexchangewebservices

解决方案


啊,SearchFilter 对我来说效果很好:

Microsoft.Exchange.WebServices.Data.SearchFilter SF = new Microsoft.Exchange.WebServices.Data.SearchFilter.IsGreaterThanOrEqualTo(Microsoft.Exchange.WebServices.Data.ItemSchema.DateTimeReceived, new System.DateTime(2019,11,20));
Microsoft.Exchange.WebServices.Data.FindItemsResults<Microsoft.Exchange.WebServices.Data.Item> Results = exchange.FindItems(Microsoft.Exchange.WebServices.Data.WellKnownFolderName.Inbox, SF, new Microsoft.Exchange.WebServices.Data.ItemView(100));

推荐阅读