ServiceMetadataBehavior.HttpGetEnabled Propriedade
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Recebe ou define um valor que indica se deve publicar metadados do serviço para recuperação usando um pedido HTTP/GET.
public:
property bool HttpGetEnabled { bool get(); void set(bool value); };
public bool HttpGetEnabled { get; set; }
member this.HttpGetEnabled : bool with get, set
Public Property HttpGetEnabled As Boolean
Valor de Propriedade
true se a WSDL for publicada; caso contrário, false. A predefinição é false.
Exemplos
O exemplo de código seguinte demonstra a utilização de ServiceMetadataBehavior num ficheiro de configuração para permitir o suporte de metadados para pedidos HTTP/GET e WS-Transfer/GET.
// Create a new metadata behavior object and set its properties to
// create a secure endpoint.
ServiceMetadataBehavior sb = new ServiceMetadataBehavior();
//sb.EnableHelpPage= true;
//sb.HttpsGetUrl = new Uri("https://myMachineName:8036/myEndpoint");
//myServiceHost.Description.Behaviors.Add(sb);
}
private void SnippetServiceMetadataBehavior()
{
// service for which <<indigo2>> automatically adds a
// ServiceMetadataBehavior to publish metadata as well as
// an HTML service help page
// from C_HowToSecureEndpoint\cs
// Create a new metadata behavior object and set its properties to
// create a secure endpoint.
ServiceMetadataBehavior sb = new ServiceMetadataBehavior();
/* sb.EnableHelpPage = true;
sb.enableMetadataExchange = true;
sb.HttpsGetUrl = new Uri("https://myMachineName:8036/myEndpoint");
myServiceHost.Description.Behaviors.Add(sb);
*/
}
private void Run()
{
// T:System.ServiceModel.ServiceMetadataBehavior
// <Snippet#0>
// Create a ServiceHost for the service type and use the base address from configuration.
ServiceHost host = new ServiceHost(typeof(SampleService));
try
{
ServiceMetadataBehavior metad
= host.Description.Behaviors.Find<ServiceMetadataBehavior>();
if (metad == null)
metad = new ServiceMetadataBehavior();
metad.HttpGetEnabled = true;
host.Description.Behaviors.Add(metad);
host.AddServiceEndpoint(
ServiceMetadataBehavior.MexContractName,
MetadataExchangeBindings.CreateMexHttpBinding(),
"mex"
);
// The service can now be accessed.
Console.WriteLine("The service is ready.");
Console.WriteLine("Press <ENTER> to terminate service.");
Console.WriteLine();
Console.ReadLine();
// Close the ServiceHostBase to shutdown the service.
host.Close();
// </Snippet#0>
Observações
Se o valor de HttpGetUrl for relativo, o endereço em que os metadados são publicados é o endereço base e o endereço de serviço mais uma ?wsdl sequência de consulta.
Se o valor de HttpGetUrl for absoluto, o endereço onde os metadados são publicados é o valor do HttpGetUrl valor mais uma ?wsdl sequência de consulta.
Por exemplo, se o endereço de serviço for http://localhost:8080/CalculatorService e o HttpGetUrl for uma cadeia vazia, o endereço de metadados HTTP/GET é http://localhost:8080/CalculatorService?wsdl.
Se não ativar esta propriedade e não a alterar HttpGetUrl ou definir para um endereço relativo, uma exceção é lançada em tempo de execução quando o host de serviço é aberto sem um endereço base para HTTP.