Usando o canal cliente Discovery
Ao escrever um aplicativo cliente WCF, você precisa saber o endereço do ponto de extremidade do serviço que você está chamando. Em muitas situações, o endereço do ponto de extremidade de um serviço não é conhecido com antecedência, ou o endereço do serviço é alterado ao longo do tempo. O canal cliente Discovery permite que você escreva um aplicativo cliente WCF e descreva o serviço que você deseja chamar, e o canal cliente envia automaticamente uma solicitação de investigação. Quando um serviço responde, o canal cliente Discovery recupera o endereço do ponto de extremidade para o serviço a partir da resposta de investigação e o usa para chamar o serviço.
Usando o canal cliente Discovery
Para usar o canal cliente Discovery, adicione uma instância de DiscoveryClientBindingElement à sua pilha de canais do cliente. Como alternativa, você pode usar o DynamicEndpoint, e um DiscoveryClientBindingElement é adicionado automaticamente à sua associação se ainda não estiver presente.
Cuidado
É recomendável que DiscoveryClientBindingElement seja o elemento mais importante na pilha de canais do cliente. Qualquer elemento de associação adicionado na parte superior do DiscoveryClientBindingElement deve garantir que o ChannelFactory ou o canal que ele cria não use o endereço do ponto de extremidade ou o endereço Via
(passado para o método CreateChannel
) porque eles podem não conter o endereço correto.
A classe DiscoveryClientBindingElement contém duas propriedades públicas:
FindCriteria, que é usada para descrever o serviço que você deseja chamar.
DiscoveryEndpointProvider, que especifica o ponto de extremidade de descoberta para o qual enviar mensagens de descoberta.
A propriedade FindCriteria permite que você especifique o contrato de serviço que está procurando, qualquer URI de escopo necessárias e o número máximo de tempo para tentar abrir o canal. O tipo de contrato é especificado chamando o construtor FindCriteria. URIs de escopo podem ser adicionados à propriedade Scopes. A propriedade MaxResults permite que você especifique o número máximo de resultados aos quais o cliente tenta se conectar. Quando uma resposta de investigação é recebida, o cliente tenta abrir o canal usando o endereço do ponto de extremidade da resposta da investigação. Se ocorrer uma exceção, o cliente passará para a próxima resposta de investigação, aguardando que mais respostas sejam recebidas, se necessário. Ele continua a fazer isso até que o canal seja aberto com êxito ou o número máximo de resultados seja atingido. Para obter mais informações sobre essas configurações, consulte FindCriteria.
A propriedade DiscoveryEndpointProvider permite que você especifique o ponto de extremidade de descoberta a ser usado. Normalmente ele é UdpDiscoveryEndpoint, mas pode ser qualquer ponto de extremidade válido.
Ao criar a associação a ser usada para se comunicar com o serviço, você deve ter o cuidado de usar exatamente a mesma associação do serviço. A única diferença é que a associação de cliente tem um DiscoveryClientBindingElement na parte superior da pilha. Se o serviço estiver usando uma das associações fornecidas pelo sistema, crie uma nova CustomBinding e passe a associação fornecida pelo sistema para o construtor CustomBinding. Em seguida, você pode adicionar DiscoveryClientBindingElement chamando Insert
na propriedade Elements.
Depois de adicionar a DiscoveryClientBindingElement à sua associação e configurá-la, você pode criar uma instância da classe de cliente WCF, abri-la e chamar seus métodos. O exemplo a seguir usa o canal cliente Discovery para descobrir um serviço WCF que implementa a classe ICalculator
(usada no tutorial de Introdução ao WCF) e chama seu método Add
.
// Create the DiscoveryClientBindingElement
DiscoveryClientBindingElement bindingElement = new DiscoveryClientBindingElement();
// Search for a service that implements the ICalculator interface, attempting to open
// the channel a maximum of 2 times
bindingElement.FindCriteria = new FindCriteria(typeof(ICalculator)) { MaxResults = 2 };
// Use the UdpDiscoveryEndpoint
bindingElement.DiscoveryEndpoint = new UdpDiscoveryEndpoint();
// The service uses the BasicHttpBinding, so use that and insert the DiscoveryClientBindingElement at the
// top of the stack
CustomBinding binding = new CustomBinding(new BasicHttpBinding());
binding.Elements.Insert(0,bindingElement);
try
{
// Create the WCF client and call a method
CalculatorClient client = new CalculatorClient(binding, new EndpointAddress("http://schemas.microsoft.com/dynamic"));
client.Open();
client.Add(1, 1);
}
catch (EndpointNotFoundException ex)
{
Console.WriteLine("An exception occurred: " + ex.Message);
}
Segurança e o canal cliente Discovery
Ao usar o canal cliente Discovery, dois pontos de extremidade estão sendo especificados. Um deles é usado para mensagens de descoberta, geralmente UdpDiscoveryEndpoint, e o outro é o ponto de extremidade do aplicativo. Ao implementar um serviço seguro, é necessário ter o cuidado de proteger os dois pontos de extremidade. Para obter mais informações sobre segurança, consulte Proteção de serviços e clientes.