ServiceMetadataBehavior.HttpGetEnabled 属性
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
获取或设置一个值,该值指示是否发布服务元数据以便使用 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
属性值
如果发布 WSDL,则为 true
;否则为 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
querystring。
如果 HttpGetUrl 的值是绝对值,则发布元数据的地址为 HttpGetUrl 值的值加上 ?wsdl
querystring。
例如,如果服务地址为 http://localhost:8080/CalculatorService
且 HttpGetUrl 为空字符串,则 HTTP/GET 元数据地址为 http://localhost:8080/CalculatorService?wsdl
。
如果不启用此属性且不更改 HttpGetUrl 或将其设置为相对地址,则在不使用 HTTP 基址打开服务主机的情况下会在运行时引发异常。