次の方法で共有


チャネル ファクトリ

このサンプルでは、クライアント アプリケーションが、生成されたクライアントではなく ChannelFactory クラスを含むチャネルを作成できる方法を示します。このサンプルは、電卓サービスを実装する「入門サンプル」に基づいています。

ms751400.note(ja-jp,VS.100).gif注 :
このサンプルのセットアップ手順とビルド手順については、このトピックの最後を参照してください。

このサンプルは、ChannelFactory クラスを使用して、サービス エンドポイントにチャネルを作成します。通常、サービス エンドポイントへのチャネルを作成するには、ServiceModel メタデータ ユーティリティ ツール (Svcutil.exe) を使用してクライアント型を生成し、生成された型のインスタンスを作成します。また、ChannelFactory クラスを使用してチャネルを作成することもできます。サンプルを参照してください。次のサンプル コードで作成されるサービスは、「入門サンプル」内のサービスと同じものです。

EndpointAddress address = new EndpointAddress("https://localhost/servicemodelsamples/service.svc");
WSHttpBinding binding = new WSHttpBinding();
ChannelFactory<ICalculator> factory = new 
                    ChannelFactory<ICalculator>(binding, address);
ICalculator channel = factory.CreateChannel();
ms751400.Important(ja-jp,VS.100).gif 注 :
このサンプルを複数コンピュータのシナリオで実行している場合は、前述のコードの "localhost" を、サービスを実行中のコンピュータの完全修飾名に置き換える必要があります。このサンプルは、エンドポイント アドレスを設定する構成を使用していません。したがって、コード内でアドレスを設定する必要があります。

チャネルが作成されたら、生成されたクライアントと同様にサービス操作を呼び出すことができます。

// Call the Add service operation.
double value1 = 100.00D;
double value2 = 15.99D;
double result = channel.Add(value1, value2);
Console.WriteLine("Add({0},{1}) = {2}", value1, value2, result);

チャネルを閉じるには、最初にチャネルを IClientChannel インターフェイスにキャストする必要があります。これは、生成されたチャネルが ICalculator インターフェイスによってクライアント アプリケーション内で宣言されているからです。このインターフェイスには Add および Subtract などのメソッドは含まれていますが、Close は含まれていません。Close メソッドは、ICommunicationObject インターフェイスで発生します。

// Close the channel.
 ((IClientChannel)client).Close();

このサンプルを実行する場合は、操作要求および応答はクライアントのコンソール ウィンドウに表示されます。クライアント アプリケーションをシャットダウンするには、クライアント ウィンドウで Enter キーを押します。

Add(100,15.99) = 115.99
Subtract(145,76.54) = 68.46
Multiply(9,81.25) = 731.25
Divide(22,7) = 3.14285714285714

Press <ENTER> to terminate client.

サンプルを設定、ビルド、および実行するには

  1. Windows Communication Foundation サンプルの 1 回限りのセットアップの手順」が実行済みであることを確認します。

  2. ソリューションの C# 版または Visual Basic .NET 版をビルドするには、「Windows Communication Foundation サンプルのビルド」の手順に従います。このサンプルではメタデータの公開は有効化されないことに注意してください。最初にこのサンプルのメタデータ公開を有効にして、クライアント型を再生成する必要があります。

  3. 単一コンピュータ構成か複数コンピュータ構成かに応じて、「Running the Windows Communication Foundation Samples」の手順に従います。

サンプルを複数コンピュータで実行するには

  1. 次のコードの "localhost" を、サービスを実行中のコンピューターの完全修飾名に置き換えます。

    EndpointAddress address = new EndpointAddress("https://localhost/servicemodelsamples/service.svc");
    
ms751400.Important(ja-jp,VS.100).gif 注 :
サンプルは、既にコンピューターにインストールされている場合があります。続行する前に、次の (既定の) ディレクトリを確認してください。

<InstallDrive>:\WF_WCF_Samples

このディレクトリが存在しない場合は、「.NET Framework 4 向けの Windows Communication Foundation (WCF) および Windows Workflow Foundation (WF) のサンプル」にアクセスして、Windows Communication Foundation (WCF) および WF のサンプルをすべてダウンロードしてください。このサンプルは、次のディレクトリに格納されます。

<InstallDrive>:\WF_WCF_Samples\WCF\Basic\Client\ChannelFactory