Фабрика каналов

В примере ChannelFactory показано, как клиентское приложение может создать канал с ChannelFactory классом вместо созданного клиента. Этот пример основан на руководстве «Начало работы», которое реализует сервис калькулятора.

Замечание

Процедура установки и инструкции по сборке для этого примера находятся в конце этого раздела.

В этом примере класс 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();

При запуске примера запросы и ответы операции отображаются в окне консоли клиента. Нажмите клавишу ВВОД в окне клиента, чтобы завершить работу клиентского приложения.

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. Убедитесь, что вы выполнили процедуру настройки One-Time для образцов Windows Communication Foundation.

  2. Чтобы создать версию решения на C# или Visual Basic .NET, следуйте инструкциям по сборке примеров Windows Communication Foundation . Обратите внимание, что этот пример не включает публикацию метаданных. Сначала необходимо включить публикацию метаданных для этого примера, чтобы повторно создать тип клиента.

  3. Чтобы запустить пример в конфигурации с одним или несколькими компьютерами, следуйте инструкциям в запуска примеров Windows Communication Foundation.

Запуск примера между компьютерами

Замените localhost в следующем коде полным именем компьютера, на котором запущена служба.

EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");