EWS マネージ API クライアント アプリケーションの概要
EWS マネージ API を使用して、Exchange 用の単純な Hello World メール クライアント アプリケーションを開発します。
EWS マネージ API では、クライアント アプリケーション、ポータル アプリケーション、サービス アプリケーションから Web サービス メッセージを送受信するための、直観的で使いやすいオブジェクト モデルが用意されています。 EWS マネージ API を使用して、Exchange Online、Office 365 の一部としての Exchange Online、Exchange サーバー メールボックスに格納されているほとんどすべての情報にアクセスすることができます。 この記事にある情報は、初めて EWS マネージ API のクライアント アプリケーションを開発する場合に役立ちます。
注:
2022 年 10 月より、Exchange Online for EWS で基本認証を使用する機能が削除されます。Exchange Online での基本認証の廃止。 代わりに OAuth 認証を使用する必要があります。 OAuth を使用して EWS アプリケーションを認証する
注:
EWS マネージ API は、GitHub でオープンソース プロジェクトとして利用可能になりました。 オープン ソース ライブラリを使用して、以下のことができます。
- バグ修正と API の機能強化に貢献します。
- 公式のリリースで利用可能になる前に、修正プログラムや拡張機能を取得できます。
- API の最も包括的かつ最新の実装にアクセスして、参照として使用するか、新しいプラットフォームで新しいライブラリを作成します。
GitHub への皆様の貢献を歓迎いたします。
Exchange サーバーが必要になります
Exchange メールボックス アカウントを既に所有している場合は、このセクションを省略してもかまいません。 それ以外の場合は、次のいずれかの方法で、初めての EWS クライアント アプリケーション用の Exchange メールボックスをセットアップします。
Office 365 開発者向けサイトを取得します (推奨)。 これが最も簡単に Exchange メールボックスをセットアップする方法です。
Exchange Server をダウンロードする。
Exchange からメールを送受信できることが確認できたら、開発環境をセットアップする準備ができています。 Exchange Web クライアントの Outlook Web App を使用して、メールが送信できることを確認します。
開発環境のセットアップ
以下にアクセスできることを確認してください。
.NET Framework 4 をサポートしているバージョンの Visual Studio。 技術的には、どの C# コンパイラでも使用できるため Visual Studio は必ず必要であるというわけではありませんが、Visual Studio を使用することをお勧めします。
EWS マネージ API。 システムに応じて、64 ビット バージョンと 32 ビット バージョンのどちらかをインストールします。 既定のインストール場所を使用します。
初めての EWS マネージ API アプリケーションの作成
次の手順は、Office 365 開発者向けサイトをセットアップすることを前提としています。 Exchange をダウンロードしてインストールした場合、Exchange サーバーに有効な証明書をインストールするか、既定で提供されている自己署名証明書用に証明書の検証コールバックを実装する必要があります。 なお、これらの手順は、使用している Visual Studio のバージョンによって若干異なる場合がありますのでご注意ください。
手順 1: Visual Studio でプロジェクトを作成する
Visual Studio の [ファイル] メニューで、 [新規] を選択してから、 [プロジェクト] を選択します。 [新しいプロジェクト] ダイアログ ボックスが表示されます。
C# コンソール アプリケーション を作成します。 [テンプレート] ウィンドウで、 [Visual C#] を選択してから、 [コンソール アプリケーション] を選択します。
プロジェクトに「HelloWorld」という名前を付けて、 [OK] を選択します。
Visual Studio は、プロジェクトを作成し、Program.cs コードのドキュメント ウィンドウを開きます。
手順 2:EWS マネージ API の参照を追加する
[ソリューション エクスプ ローラー] ウィンドウが既に開いている場合、この手順を省略し、手順 2 に進みます。 [ソリューション エクスプ ローラー] ウィンドウを開くには、 [ビュー] メニューで [ソリューション エクスプ ローラー] を選択します。
[ソリューション エクスプ ローラー] の HelloWorld プロジェクトで [参照] のショートカット メニュー (右クリック) を開き、コンテキスト メニューから [参照の追加] を選択します。 プロジェクトの参照を管理するためのダイアログ ボックスが開きます。
[参照] オプションを選択します。 EWS マネージ API DLL がインストールされている場所を参照します。 インストーラーによって設定される既定のパスは、C:\Program Files\Microsoft\Exchange\Web Services<バージョン>です。 このパスは、32 ビットと 64 ビットのどちらのバージョンの Microsoft.Exchange.WebServices.dll をダウンロードするかによって異なります。 Microsoft.Exchange.WebServices.dll を選択し、[OK] または [追加] を選択します。 これによって、EWS マネージ API リファレンスがプロジェクトに追加されます。
EWS Managed API 2.0 を使用している場合は, .NET Framework 4 を対象とするよう HelloWorld プロジェクトを変更します。 EWS マネージ API の他のバージョンでは、別の .NET Framework のターゲット バージョンを使用する可能性があります。
正しい .NET Framework のターゲット バージョンを使用していることを確認します。 [ソリューション エクスプ ローラー] で、 HelloWorld プロジェクトのショートカット メニュー (右クリック) を開き、 [プロパティ] を選択します。 [ターゲット フレームワーク] ドロップダウン ボックスで、 [.NET Framework 4] が選択されていることを確認します。
プロジェクトをセットアップし、EWS マネージ API への参照を作成したので、最初のアプリケーションを作成する準備ができました。 簡潔にするために、Program.cs ファイルにコードを追加します。 EWS マネージ API の参照の詳細については、「EWS のマネージ API のアセンブリを参照する」を参照してください。 次の手順では、ほとんどの EWS マネージ API クライアント アプリケーションを作成するための基本的なコードを開発します。]
手順 3:自動検出のための URL リダイレクト検証を設定します。
Main(string[] args) メソッドの後に、次のリダイレクト検証コールバック メソッドを追加します。 これは、 自動検出によって返される、リダイレクトされた URL が HTTPS エンドポイントを表すかどうかを検証します。
private static bool RedirectionUrlValidationCallback(string redirectionUrl) { // The default for the validation callback is to reject the URL. bool result = false; Uri redirectionUri = new Uri(redirectionUrl); // Validate the contents of the redirection URL. In this simple validation // callback, the redirection URL is considered valid if it is using HTTPS // to encrypt the authentication credentials. if (redirectionUri.Scheme == "https") { result = true; } return result; }
この検証コールバックは、手順 4 で ExchangeService オブジェクトに渡されます。 これは、アプリケーションが自動検出リダイレクトを信頼して従うようにするために必要です。自動検出リダイレクトの結果は、アプリケーションの EWS エンドポイントを提供します。
手順 4:ExchangeService オブジェクトを準備する
using ディレクティブ参照を EWS マネージ API に追加します。 Program.cs の上部の最後の using ディレクティブに次のコードを追加します。
using Microsoft.Exchange.WebServices.Data;
Main メソッドで、対象とするサービス バージョンの ExchangeService オブジェクトをインスタン化します。 この例では、EWS スキーマの初期のバージョンを対象とします。
ExchangeService service = new ExchangeService(ExchangeVersion.Exchange2007_SP1);
Exchange オンプレミス サーバーを対象としており、クライアントがドメインに参加している場合は、手順 4 に進みます。 クライアントが Exchange Online または Office 365 開発者向けサイトのメールボックスを対象としている場合、明示的な資格情報を渡す必要があります。 ExchangeService オブジェクトのインスタンス化の後ろに次のコードを追加し、メールボックス アカウントの資格情報を設定します。 ユーザー名は、ユーザー プリンシパル名でなければなりません。 手順 5 に進んでください。
service.Credentials = new WebCredentials("user1@contoso.com", "password");
オンプレミスの Exchange サーバーを対象とするドメイン参加済みクライアントは、資格情報がメールボックスに関連付けられていると仮定して、ログオンしているユーザーの既定の資格情報を使用できます。 ExchangeService オブジェクトのインスタンス化の後に、次のコードを追加します。
service.UseDefaultCredentials = true;
クライアントが Exchange Online または Office 365 開発者向けサイトのメールボックスを対象とする場合、UseDefaultCredentials が既定値である false に設定されていることを確認します。 クライアントは、EWS サービスを呼び出すサービス URL を取得するために自動検出サービスの最初の呼び出しを行う準備ができました。
ExchangeService オブジェクトの AutodiscoverUrl メソッドは、自動検出サービスに対して一連の呼び出しを実行してサービス URL を取得します。 このメソッドの呼び出しが成功した場合、 ExchangeService オブジェクトの URL プロパティがサービス URL を使用して設定されます。 ユーザーのメール アドレスおよび RedirectionUrlValidationCallback を AutodiscoverUrl メソッドに渡します。 手順 3 または 手順 4 で資格情報を指定したら、次のコードを追加します。 自動検出サービスが EWS エンドポイントを見つけられるように、メール アドレスに変更
user1@contoso.com
します。service.AutodiscoverUrl("user1@contoso.com", RedirectionUrlValidationCallback);
この時点で、EWS を呼び出してメールボックスのデータにアクセスできるようにクライアントが設定されています。 コードを今すぐ実行する場合は、ExchangeService.Url プロパティの内容を調べて、 AutodiscoverUrl メソッド呼び出しが動作することを確認してください。 このプロパティに URL が含まれる場合、呼び出しは正常に行われています。 これは、アプリケーションが正常にサービスで認証され、メールボックスの EWS エンドポイントを検出したことを意味します。 これで、初めての EWS の呼び出しを行う準備が整いました。 EWS URL の設定の詳細については、「EWS Managed API を使用して EWS サービス URL を設定する」を参照してください。
手順 6:初めての Hello World メール メッセージを作成する
AutodiscoverUrl メソッド呼び出しの後に、新しい EmailMessage オブジェクトをインスタンス化し、作成したサービス オブジェクトに渡します。
EmailMessage email = new EmailMessage(service);
これで、サービス バインドが設定されているメール メッセージが作成されます。 EmailMessage オブジェクトで開始されるすべての呼び出しは、サービスの対象となります。
次に、メール メッセージの宛先行の受信者を設定します。 これを行うには、SMTP アドレスを使用するように変更
user1@contoso.com
します。email.ToRecipients.Add("user1@contoso.com");
メール メッセージの件名および本文を設定します。
email.Subject = "HelloWorld"; email.Body = new MessageBody("This is the first email I've sent by using the EWS Managed API.");
EWS マネージ API を使用して、最初のメール メッセージを送信する準備が整いました。 Send メソッドは、サービスを呼び出し、配信用にメール メッセージを送信します。 Exchange と通信するために使用できる他の方法について詳しくは、「EWS マネージ API を使用して EWS と通信する」をお読みください。
email.Send();
Hello World アプリケーションを実行する準備が整いました。 Visual Studio で、 [F5] を選択します。 空のコンソール ウィンドウが開きます。 アプリケーションが認証を行い、自動検出リダイレクトに従い、自分自身に送信するメール メッセージを作成するための最初の呼び出しを行っている間、コンソール ウィンドウには何も表示されません。 実行されている呼び出しを表示する場合は、 AutodiscoverUrl メソッドが呼び出される前のところに次の 2 行のコードを追加します。 F5 キーを押します。 これで、コンソール ウィンドウに EWS 要求と応答のトレースが出力されます。
service.TraceEnabled = true; service.TraceFlags = TraceFlags.All;
EWS マネージ API クライアント アプリケーションが作動するようになりました。 利便性を考慮して、次の使用例では、Hello World アプリケーションを作成するために Program.cs に追加したすべてのコードを示します。
using System;
using Microsoft.Exchange.WebServices.Data;
namespace HelloWorld
{
class Program
{
static void Main(string[] args)
{
ExchangeService service = new ExchangeService(ExchangeVersion.Exchange2007_SP1);
service.Credentials = new WebCredentials("user1@contoso.com", "password");
service.TraceEnabled = true;
service.TraceFlags = TraceFlags.All;
service.AutodiscoverUrl("user1@contoso.com", RedirectionUrlValidationCallback);
EmailMessage email = new EmailMessage(service);
email.ToRecipients.Add("user1@contoso.com");
email.Subject = "HelloWorld";
email.Body = new MessageBody("This is the first email I've sent by using the EWS Managed API");
email.Send();
}
private static bool RedirectionUrlValidationCallback(string redirectionUrl)
{
// The default for the validation callback is to reject the URL.
bool result = false;
Uri redirectionUri = new Uri(redirectionUrl);
// Validate the contents of the redirection URL. In this simple validation
// callback, the redirection URL is considered valid if it is using HTTPS
// to encrypt the authentication credentials.
if (redirectionUri.Scheme == "https")
{
result = true;
}
return result;
}
}
}
次の手順
最初の EWS マネージ API クライアント アプリケーションでより多くの作業を行う準備ができている場合、次のリソースを参照します。
カスタム アプリケーションで問題が発生したときには、質問やコメントをフォーラムに投稿してみてください (最初の投稿は忘れずにお読みください)。