Фабрика каналов
В этом образце показано, как клиентское приложение может создать канал с помощью ChannelFactory, вместо использования созданного клиента. Данный образец основан на образце Образец для начала работы, реализующем службу калькулятора.
![]() |
---|
Процедура установки и инструкции по построению для данного образца расположены в конце этого раздела. |
Чтобы создать канал для конечной точки службы, в этом образце используется класс ChannelFactory. Обычно, чтобы создать канал для конечной точки, с помощью средства Служебное средство ServiceModel Metadata Utility Tool (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();
![]() |
---|
Если этот образец выполняется на нескольких компьютерах, в предыдущем фрагменте кода необходимо заменить 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.
Настройка, построение и выполнение образца
Убедитесь, что выполнены процедуры, описанные в разделе Процедура однократной настройки образцов Windows Communication Foundation.
Чтобы выполнить построение версии решения для языка C# или Visual Basic .NET, воспользуйтесь инструкциями в разделе Построение образцов Windows Communication Foundation. Обратите внимание, что этот в этом образце не включается публикация метаданных. Чтобы заново создать тип клиента, необходимо включить в образце публикацию метаданных.
Чтобы выполнить образец на одном или нескольких компьютерах, выполните инструкции в разделе Running the Windows Communication Foundation Samples.
Запуск образца на нескольких компьютерах
В следующем фрагменте кода замените localhost на полное имя компьютера, на котором выполняется служба.
EndpointAddress address = new EndpointAddress("https://localhost/servicemodelsamples/service.svc");
![]() |
---|
Образцы уже могут быть установлены на компьютере. Перед продолжением проверьте следующий каталог (по умолчанию).
<диск_установки>:\WF_WCF_Samples
Если этот каталог не существует, перейдите на страницу Образцы Windows Communication Foundation (WCF) и Windows Workflow Foundation (WF) для .NET Framework 4, чтобы загрузить все образцы Windows Communication Foundation (WCF) и WF. Этот образец расположен в следующем каталоге.
<диск_установки>:\WF_WCF_Samples\WCF\Basic\Client\ChannelFactory
|