MetadataResolver Класс
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Извлекает и импортирует метаданные как объекты ServiceEndpoint.
public ref class MetadataResolver abstract sealed
public static class MetadataResolver
type MetadataResolver = class
Public Class MetadataResolver
- Наследование
-
MetadataResolver
Примеры
В следующем примере кода показано применение класса MetadataResolver для возвращения метаданных как коллекции объектов ServiceEndpoint, которые затем используются для подключения к экземпляру службы.
// Get the endpoints for such a service
ServiceEndpointCollection endpoints = MetadataResolver.Resolve(typeof(SampleServiceClient), metaAddress);
Console.WriteLine("Trying all available WS-Transfer metadata endpoints...");
foreach (ServiceEndpoint point in endpoints)
{
if (point != null)
{
// Create a new wcfClient using retrieved endpoints.
wcfClient = new SampleServiceClient(point.Binding, point.Address);
Console.WriteLine(
wcfClient.SampleMethod("Client used the "
+ point.Address.ToString()
+ " address.")
);
wcfClient.Close();
}
}
В следующем примере кода показано применение MetadataResolver для загрузки и возвращения метаданных как коллекции объектов ServiceEndpoint с помощью запроса HTTP GET, а не WS-Transfer.
// Get the endpoints for such a service using Http/Get request
endpoints = MetadataResolver.Resolve(typeof(SampleServiceClient), httpGetMetaAddress.Uri, MetadataExchangeClientMode.HttpGet);
Client.WriteParameters(endpoints);
ISampleService serviceChannel;
Console.WriteLine(
"\r\nTrying all endpoints from HTTP/Get and with direct service channels...");
foreach (ServiceEndpoint point in endpoints)
{
if (point != null)
{
ChannelFactory<ISampleService> factory = new ChannelFactory<ISampleService>(point.Binding);
factory.Endpoint.Address = point.Address;
serviceChannel = factory.CreateChannel();
Console.WriteLine("Client used the " + point.Address.ToString() + " address.");
Console.WriteLine(
serviceChannel.SampleMethod(
"Client used the " + point.Address.ToString() + " address."
)
);
factory.Close();
}
}
Комментарии
Используйте класс MetadataResolver, чтобы быстро импортировать конечные точки для службы из метаданных. Этот класс загружает и преобразовывает метаданные в объекты ServiceEndpoint. Чтобы загрузить метаданные и обработать эти сведения как System.ServiceModel.Description.MetadataSet, см. раздел System.ServiceModel.Description.MetadataExchangeClient.
Методы
BeginResolve(IEnumerable<ContractDescription>, EndpointAddress, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданных контрактов, с помощью заданного адреса и асинхронного состояния, и делегата. |
BeginResolve(IEnumerable<ContractDescription>, EndpointAddress, MetadataExchangeClient, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданных контрактов, с помощью заданного адреса, MetadataExchangeClient, асинхронного состояния и делегата. |
BeginResolve(IEnumerable<ContractDescription>, Uri, MetadataExchangeClientMode, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданных контрактов, с помощью заданного адреса, MetadataExchangeClientMode, асинхронного состояния и делегата. |
BeginResolve(IEnumerable<ContractDescription>, Uri, MetadataExchangeClientMode, MetadataExchangeClient, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданных контрактов, с помощью заданного адреса MetadataExchangeClientMetadataExchangeClientMode, асинхронного состояния и делегата. |
BeginResolve(Type, EndpointAddress, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданного контракта, с помощью заданного адреса и асинхронного состояния, и делегата. |
BeginResolve(Type, Uri, MetadataExchangeClientMode, AsyncCallback, Object) |
Начинает асинхронный вызов, разрешающий адрес метаданных в объекты ServiceEndpoint для заданного контракта, с помощью заданного адреса, MetadataExchangeClientMode, асинхронного состояния и делегата. |
EndResolve(IAsyncResult) |
Завершает асинхронный вызов для разрешения метаданных в коллекцию конечных точек. |
Resolve(IEnumerable<ContractDescription>, EndpointAddress) |
Разрешает адрес метаданных в объекты ServiceEndpoint для заданных контрактов с помощью заданного адреса метаданных. |
Resolve(IEnumerable<ContractDescription>, EndpointAddress, MetadataExchangeClient) |
Разрешает адрес метаданных в объекты ServiceEndpoint для заданных контрактов с помощью заданного адреса метаданных и MetadataExchangeClient. |
Resolve(IEnumerable<ContractDescription>, Uri, MetadataExchangeClientMode) |
Разрешает адрес метаданных в объекты ServiceEndpoint для заданных контрактов с помощью заданного адреса и режима передачи. |
Resolve(IEnumerable<ContractDescription>, Uri, MetadataExchangeClientMode, MetadataExchangeClient) |
Разрешает адрес метаданных в объекты ServiceEndpoint для заданных контрактов с помощью заданного адреса, режима передачи и клиента передачи. |
Resolve(Type, EndpointAddress) |
Загружает и разрешает адрес метаданных в коллекцию объектов ServiceEndpoint для заданного контракта по заданному адресу. |
Resolve(Type, Uri, MetadataExchangeClientMode) |
Разрешает адрес метаданных в объекты ServiceEndpoint для заданного контракта с помощью заданного адреса и режима передачи. |