チャネル ファクトリ
ChannelFactory サンプルでは、クライアント アプリケーションが、生成されたクライアントではなく ChannelFactory クラスを含むチャネルを作成できる方法を示します。 このサンプルは、電卓サービスを実装する「入門サンプル」に基づいています。
Note
このサンプルのセットアップ手順とビルド手順については、このトピックの最後を参照してください。
このサンプルは、ChannelFactory<TChannel> クラスを使用して、サービス エンドポイントにチャネルを作成します。 通常、サービス エンドポイントへのチャネルを作成するには、ServiceModel メタデータ ユーティリティ ツール (Svcutil.exe) を使用してクライアント型を生成し、生成された型のインスタンスを作成します。 また、ChannelFactory<TChannel> クラスを使用してチャネルを作成することもできます。サンプルを参照してください。 次のサンプル コードで作成されるサービスは、「入門サンプル」のサービスと同じものです。
EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");
WSHttpBinding binding = new WSHttpBinding();
ChannelFactory<ICalculator> factory = new
ChannelFactory<ICalculator>(binding, address);
ICalculator channel = factory.CreateChannel();
重要
このサンプルを複数コンピュータのシナリオで実行している場合は、前述のコードの "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.
サンプルをセットアップ、ビルド、および実行するには
Windows Communication Foundation サンプルの 1 回限りのセットアップの手順を実行したことを確認します。
ソリューションの C# 版または Visual Basic .NET 版をビルドするには、「 Building the Windows Communication Foundation Samples」の手順に従います。 このサンプルではメタデータの公開は有効化されないことに注意してください。 最初にこのサンプルのメタデータ公開を有効にして、クライアント型を再生成する必要があります。
単一または複数コンピューター構成でサンプルを実行するには、「Windows Communication Foundation サンプルの実行」の手順に従います。
サンプルを複数コンピュータで実行するには
次のコードの "localhost" を、サービスを実行中のコンピューターの完全修飾名に置き換えます。
EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");