ServiceMetadataBehavior.HttpGetEnabled Proprietà
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Ottiene o imposta un valore che indica se pubblicare i metadati del servizio per il recupero tramite una richiesta 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
Valore della proprietà
true se il file WSDL viene pubblicato; in caso contrario, false. Il valore predefinito è false.
Esempio
L'esempio di codice seguente illustra l'uso di in un file di ServiceMetadataBehavior configurazione per abilitare il supporto dei metadati per le richieste 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>
Commenti
Se il valore di HttpGetUrl è relativo, l'indirizzo in corrispondenza del quale i metadati vengono pubblicati è l'indirizzo di base e l'indirizzo del servizio più una ?wsdl stringa di query.
Se il valore di HttpGetUrl è assoluto, l'indirizzo in corrispondenza del quale vengono pubblicati i metadati è il valore di HttpGetUrl più una ?wsdl stringa di query.
Ad esempio, se l'indirizzo del servizio è http://localhost:8080/CalculatorService e HttpGetUrl è una stringa vuota, l'indirizzo dei metadati HTTP/GET è http://localhost:8080/CalculatorService?wsdl.
Se questa proprietà non viene abilitata e non viene modificata HttpGetUrl o impostata su un indirizzo relativo, viene generata un'eccezione in fase di esecuzione quando l'host del servizio viene aperto senza un indirizzo di base per HTTP.