Поделиться через


ServiceMetadataBehavior.HttpGetEnabled Свойство

Определение

Возвращает или задает значение, указывающее, следует ли опубликовывать метаданные службы для извлечения с помощью запроса 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

Значение свойства

true, если язык WSDL является опубликованным; в противном случае — false. Значение по умолчанию — false.

Примеры

В следующем примере кода показано применение ServiceMetadataBehavior в файле конфигурации для включения поддержки метаданных для запросов HTTP/GET и 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>

Комментарии

Если значение HttpGetUrl является относительным, адрес, в котором опубликовываются метаданные, является базовым адресом и адресом службы плюс строка запроса ?wsdl.

Если значение HttpGetUrl является абсолютным, адрес, в котором опубликовываются метаданные, является значение значения HttpGetUrl плюс строка запроса ?wsdl.

Например, если адресом службы является http://localhost:8080/CalculatorService, а HttpGetUrl является пустой строкой, адресом метаданных HTTP/GET является http://localhost:8080/CalculatorService?wsdl.

Если это свойство не будет включено и не будет изменено HttpGetUrl или ему не будет задан относительный адрес, во время выполнения возникнет исключение при открытии узла службы без базового адреса для HTTP.

Применяется к