[WCF REST] WebServiceHost有何特别之处?
2012-02-08 09:00
811 查看
WCF为REST服务的寄宿提供了一个新的ServiceHost,即WebServiceHost。WebServiceHost是ServiceHost的子类,而WebServiceHostFactory是对应的ServiceHostFactory,在基于IIS/WAS寄宿中被使用。由于对REST服务绝大部分功能的支持都是通过WebHttpBehavior这么一个终结点行为实现的,所以WebServiceHost的核心功能就是将该终结点行为应用到寄宿服务的所有终结点。除此之外,WebServiceHost还具有一些额外的功能,这些功能都是通过重写OnOpening方法实现的。
[/code]
在如上所示的代码片断中,我们分别将服务行为ServiceDebugBehavior和ServiceMetadataBehavior应用在寄宿服务上,并将其HttpHelpPageEnabled/HttpsHelpPageEnabled和HttpGetEnabled/HttpsGetEnabled属性设置为True。在开启WebServiceHost之后我们将两个服务行为的这4个属性打印出来。从如下所示的输出结果我们可以看出这四个属性最终被设置成了False。
[/code]
[/code]
在没有提供任何配置的情况下,我们通过如上的代码借助于WebServiceHost进行服务寄宿。在基于服务类型创建的WebServiceHost中指定了一个基地址,并在开启WebServiceHost之后,我们获取第一个终结点并将其三要素打印出来。从如下所示的输出结果我们可以看出:WebServiceHost基于服务类型实现的契约接口IEmployees创建了一个终结点,该终结点采用指定的基地址作为其地址,绑定类型为WebHttpBinding。
[/code]
[/code]
一、ServiceDebugBehavior与ServiceMetadataBehavior
由于WebHttpBehavior提供了帮助页面,所以当我们通过WebServiceHost对REST服务进行寄宿的时候会屏蔽掉通过ServiceDebugBehavior服务行为提供的帮助页面。由于通过服务行为ServiceMetadataBehavior实现的元数据发布机制是基于SOAP的,如果我们在寄宿服务上应用了ServiceMetadataBehavior行为,WebServiceHost也会将基于HTTP-GET的元数据发布功能屏蔽。我们可以通过一个简单的实例来证实这一点。[code] using (WebServiceHost host = new WebServiceHost(typeof(EmployeesService))) { ServiceDebugBehavior serviceDebug = host.Description.Behaviors.Find<ServiceDebugBehavior>(); if (null == serviceDebug) { serviceDebug = new ServiceDebugBehavior(); host.Description.Behaviors.Add(serviceDebug); } serviceDebug.HttpHelpPageEnabled = true; serviceDebug.HttpsHelpPageEnabled = true; ServiceMetadataBehavior serviceMetadata = host.Description.Behaviors.Find<ServiceMetadataBehavior>(); if (null == serviceMetadata) { serviceMetadata = new ServiceMetadataBehavior(); host.Description.Behaviors.Add(serviceMetadata); } serviceMetadata.HttpGetEnabled = true; serviceMetadata.HttpsGetEnabled = true; host.Open(); Console.WriteLine("ServiceDebugBehavior"); Console.WriteLine("\t{0, -20}: {1}", "HttpHelpPageEnabled", serviceDebug.HttpHelpPageEnabled); Console.WriteLine("\t{0, -20}: {1}\n", "HttpsHelpPageEnabled", serviceDebug.HttpsHelpPageEnabled); Console.WriteLine("ServiceMetadataBehavior"); Console.WriteLine("\t{0, -20}: {1}", "HttpGetEnabled", serviceMetadata.HttpGetEnabled); Console.WriteLine("\t{0, -20}: {1}", "HttpsGetEnabled", serviceMetadata.HttpsGetEnabled); }
[/code]
在如上所示的代码片断中,我们分别将服务行为ServiceDebugBehavior和ServiceMetadataBehavior应用在寄宿服务上,并将其HttpHelpPageEnabled/HttpsHelpPageEnabled和HttpGetEnabled/HttpsGetEnabled属性设置为True。在开启WebServiceHost之后我们将两个服务行为的这4个属性打印出来。从如下所示的输出结果我们可以看出这四个属性最终被设置成了False。
[code] ServiceDebugBehavior HttpHelpPageEnabled : False HttpsHelpPageEnabled: False ServiceMetadataBehavior HttpGetEnabled : False HttpsGetEnabled : False
[/code]
二、添加标准终结点
终结点是由地址、绑定和契约三要素构成,所谓标准终结点,就是基于典型的通信场景选择组成终结点的要素(主要是绑定和契约)进而创建出一个标准的终结点。如果我们在使用WebServiceHost进行服务寄宿的时候指定一个基地址,在没有添加任何终结点的情况下WebServiceHost会在开启过程中自动添加一个类型(Kind)为webHttpEndpoint 的标准终结点。我们同样可以通过实例演示来证实这一点。[code] Uri baseAddress = new Uri("http://127.0.0.1:3721/employees"); using (WebServiceHost host = new WebServiceHost(typeof(EmployeesService), baseAddress)) { host.Open(); ServiceEndpoint endpoinit = host.Description.Endpoints[0]; Console.WriteLine("{0,-8}: {1}", "Address", endpoinit.Address); Console.WriteLine("{0,-8}: {1}", "Binding", endpoinit.Binding); Console.WriteLine("{0,-8}: {1}", "Contract", endpoinit.Contract.ContractType); }
[/code]
在没有提供任何配置的情况下,我们通过如上的代码借助于WebServiceHost进行服务寄宿。在基于服务类型创建的WebServiceHost中指定了一个基地址,并在开启WebServiceHost之后,我们获取第一个终结点并将其三要素打印出来。从如下所示的输出结果我们可以看出:WebServiceHost基于服务类型实现的契约接口IEmployees创建了一个终结点,该终结点采用指定的基地址作为其地址,绑定类型为WebHttpBinding。
[code] Address : http://127.0.0.1:3721/employees Binding : System.ServiceModel.WebHttpBinding Contract: Artech.WcfServices.Service.Interface.IEmployees
[/code]
三、添加WebHttpBehavior终结点行为
正如上面所说,WebServiceHost除了完成从ServiceHost继承下来的服务寄宿功能之外,其只要的职责就是将WebHttpBehavior行为应用到寄宿服务的所有终结点上。也就是说,当我们开启WebServiceHost的时候,如果终结点没有应用WebHttpBehavior行为,会自动创建一个新的WebHttpBehavior对象应用到终结点上。WebHttpBehavior的自动添加可以通过如下代码中的调试断言来体现。[code] using (WebServiceHost host = new WebServiceHost(typeof(EmployeesService))) { foreach (ServiceEndpoint endpoint in host.Description.Endpoints) { WebHttpBehavior behavior = endpoint.Behaviors.Find<WebHttpBehavior>(); if (null != behavior) { endpoint.Behaviors.Remove(behavior); } } host.Open(); foreach (ServiceEndpoint endpoint in host.Description.Endpoints) { Debug.Assert(null != endpoint.Behaviors.Find<WebHttpBehavior>()); } }
[/code]
相关文章推荐
- [WCF REST] WebServiceHost有何特别之处?
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- 创建一个既支持WSDL又支持REST的WCFWebService
- WCF、WebAPI、WCFREST、WebService之间的区别
- 转:WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF,WebAPI,WCFREST和WebService的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- 创建一个既支持WSDL又支持REST的WCFWebService
- 不用webservice wcf提供服务,用Rest更轻量
- WCF 定义SOAP和REST风格的webservice
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- WCF、WebAPI、WCFREST、WebService之间的区别
- 4000 WCF、WebAPI、WCFREST、WebService之间的区别