Ескертпе
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Жүйеге кіруді немесе каталогтарды өзгертуді байқап көруге болады.
Бұл бетке кіру үшін қатынас шегін айқындау қажет. Каталогтарды өзгертуді байқап көруге болады.
В примере 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.
Настройка, сборка и запуск примера
Убедитесь, что вы выполнили процедуру настройки One-Time для образцов Windows Communication Foundation.
Чтобы создать версию решения на C# или Visual Basic .NET, следуйте инструкциям по сборке примеров Windows Communication Foundation . Обратите внимание, что этот пример не включает публикацию метаданных. Сначала необходимо включить публикацию метаданных для этого примера, чтобы повторно создать тип клиента.
Чтобы запустить пример в конфигурации с одним или несколькими компьютерами, следуйте инструкциям в запуска примеров Windows Communication Foundation.
Запуск примера между компьютерами
Замените localhost в следующем коде полным именем компьютера, на котором запущена служба.
EndpointAddress address = new EndpointAddress("http://localhost/servicemodelsamples/service.svc");