Windows Communication Foundation のバインディングの概要
バインディングとは、Windows Communication Foundation (WCF) サービスのエンドポイントへの接続に必要な通信の詳細設定を指定する際に使用するオブジェクトのことです。 WCF サービスの各エンドポイントに、バインドを正しく指定する必要があります。 ここでは、バインディングによって定義される通信の詳細設定の種類、バインディングの要素、WCF に用意されているバインディング、およびエンドポイントにバインディングを指定する方法について説明します。
バインディングの定義内容
バインディングの情報は非常に基本的にも複雑にもなりえます。 最も基本的なバインディングはトランスポート プロトコル (HTTP など) のみを指定したもので、これはエンドポイントへの接続に必ず使用します。 一般的に、バインディングに含まれるエンドポイントへの接続方法を示す情報は、次のカテゴリのいずれかに当てはまります。
プロトコル
使用されているセキュリティ機構 (信頼性の高いメッセージング機能またはトランザクション コンテキストのフロー設定のいずれか) を決定します。
[エンコード]
メッセージ エンコーディング (テキストまたはバイナリなど) を決定します。
トランスポート
使用する基本のトランスポート プロトコル (TCP や HTTP など) を決定します。
バインディングの要素
バインディングは、基本的に、バインド要素の順序付きスタックで構成されます。各バインド要素では、サービス エンドポイントに接続するために必要な通信情報の一部を指定します。 スタックの 2 つの最も低い層は両方とも必須です。 スタックの一番下にトランスポート バインド要素があり、そのすぐ上にメッセージ エンコーディング仕様を含んだ要素があります。 その他の通信プロトコルを指定するオプションのバインド要素は、この 2 つの必須要素の上に配置されます。 これらのバインド要素とその正しい順序の詳細については、「カスタム バインディング」を参照してください。
システム標準のバインディング
バインディングの情報は複雑になる可能性があり、一部の設定は他の設定と互換性がない場合もあります。 このため、WCF には、システム指定のバインディングが用意されています。 このバインディングは、アプリケーション要件のほとんどに対応するように設計されています。 システム指定のバインディングの例のいくつかを次のクラスで示します。
BasicHttpBinding : WS-I Basic Profile 仕様に準拠する Web サービス (ASP.NET Web サービス ベースのサービスなど) への接続に適した HTTP プロトコル バインディング。
WSHttpBinding : WS-* プロトコルに準拠するエンドポイントへの接続に適した相互運用可能なバインディング。
NetNamedPipeBinding: 同じコンピューター上の他の WCF エンドポイントへの接続に .NET Framework を使用します。
NetMsmqBinding: キューに置かれたメッセージと他の WCF エンドポイントとの接続を作成するために .NET Framework を使用します。
NetTcpBinding: このバインディングでは、HTTP バインディングよりも高いパフォーマンスが得られるので、ローカル ネットワークでの使用に最適です。
WCF 指定のバインディングの完全な一覧と説明については、「システム指定のバインド」を参照してください。
独自のバインディングの使用
システム指定のバインディングに、サービス アプリケーションに必要な正しい組み合わせの機能がない場合、独自のバインディングを作成できます。 これには、2 つの方法があります。 CustomBinding オブジェクトを使用して既存のバインド要素から新しいバインディングを作成するか、Binding バインディングから派生することによって完全にユーザー定義のバインディングを作成することができます。 この 2 つの方法を使用して独自のバインディングを作成する方法の詳細については、「カスタム バインディング」と「ユーザー定義バインディングの作成」を参照してください。
バインディングの使用
バインディングを使用する際には、次の 2 つの基本手順があります。
バインディングを選択、または定義します。 最も簡単な方法は、WCF に用意されているシステム指定のバインディングを 1 つ選択し、それを既定の設定で使用することです。 また、システム指定のバインディングを選択し、そのプロパティを要件に適した値に再設定することもできます。 別の方法として、カスタム バインドまたはユーザー定義バインディングを作成し、より高度な制御とカスタマイズを実現することができます。
選択または定義されたバインディングを使用するエンドポイントを作成します。
コードおよび構成
バインディングを定義するには、コードによる方法と構成による方法の 2 とおりがあります。 この 2 つの方法は、システム指定またはカスタムのどちらのバインディングを使用している場合でも有効です。 一般的には、コードを使用すると、開発者がデザイン時にバインディングの定義を完全に制御することになります。 一方、構成を使用する場合は、システム管理者や、WCF サービスまたはクライアントのユーザーが、サービス アプリケーションをコンパイルし直すことなくバインディングのパラメーターを変更できます。 通常は、WCF アプリケーションの展開先の具体的なコンピューター要件を予測する方法がないため、柔軟性のあるこの方法が望まれます。 バインディング情報とアドレス情報をコードに含めないでおくと、これらの情報を変更したときにアプリケーションを再度コンパイルしたり、展開したりする必要がなくなります。 コードで定義したバインディングは、構成で指定したバインディングの後に作成されます。そのため、構成で定義したバインディングはコードで定義したバインディングによって上書きされることに注意してください。