WCF行為類型基本概念簡(jiǎn)述
開(kāi)發(fā)人員在應(yīng)用WCF開(kāi)發(fā)工具進(jìn)行實(shí)際編程時(shí),可以利用這一平臺(tái)打造一個(gè)安全性技巧的解決方案,幫助我們解決一些特定問(wèn)題。下面,我們首先來(lái)看看有關(guān)WCF行為類型的相關(guān)介紹,方便大家學(xué)習(xí)。#t#
WCF行為類型總共可以分為四種:服務(wù)行為、終結(jié)點(diǎn)行為、契約行為和操作行為。 這四種行為分別定義了四個(gè)接口:IServiceBehavior,IEndpointBehavior,IContractBehavior以及 IOperationBehavior。雖然是四個(gè)不同的接口,但它們的接口方法卻基本相同,分別為 AddBindingParameters(),ApplyClientBehavior()以及ApplyDispatchBehavior()。
注 意,IServiceBehavior由于只能作用在服務(wù)端,因此并不包含ApplyClientBehavior()方法。
我們可以定義自己的類實(shí)現(xiàn)這些WCF行為類型的接口,但需要注意幾點(diǎn):
1、行為的作用范圍,可以用如下表格表示:
2、可以利用自定義特性的方式添加擴(kuò)展的服務(wù)行為、契約行為和操作行為,但不能添加終結(jié)點(diǎn)行為;可以利用配置文件添加擴(kuò)展服務(wù)行為和終結(jié)點(diǎn)行為,但不能添加契約行為和操作行為。但這些擴(kuò)展的行為都可以通過(guò)ServiceDescription添加。
利用特性添加行為,意味著我們?cè)诙x自己的擴(kuò)展行為時(shí),可以將其派生自Attribute類,然后以特性方式添加。例如:
- [AttributeUsage(AttributeTargets.Class|AttributeTargets.Interface)]
- public class MyServiceBehavior:Attribute, IServiceBehavior...
- [MyServiceBehavior]
- public interface IService...
如果以配置文件的方式添加WCF行為類型,則必須定義一個(gè)類繼承自BehaviorExtensionElement(屬于命名空間System.ServiceModel.Configuration),然后重寫屬性BehaviorType以及 CreateBehavior()方法。BehaviorType屬性返回的是擴(kuò)展行為的類型,而CreateBehavior()方法則負(fù)責(zé)創(chuàng)建該擴(kuò)展 行為的對(duì)象實(shí)例:
- public class MyBehaviorExtensionElement:BehaviorExtensionElement
- {
- public MyBehaviorExtensionElement() { }
- public override Type BehaviorType
- {
- get { return typeof(MyServiceBehavior); }
- }
- protected override object CreateBehavior()
- {
- return new MyServiceBehavior();
- }
- }
如果配置的Element添加了新的屬性,則需要為新增的屬性應(yīng)用ConfigurationPropertyAttribute,例如:
- [ConfigurationProperty("providerName",IsRequired = true)]
- public virtual string ProviderName
- {
- get
- {
- return this["ProviderName"] as string;
- }
- set
- {
- this["ProviderName"] = value;
- }
- }
配置文件中的配置方法如下所示:
- < configuration>
- < system.serviceModel>
- < services>
- < service name="MessageInspectorDemo.Calculator">
- < endpoint behaviorConfiguration="messageInspectorBehavior"
- address="http://localhost:801/Calculator"
- binding="basicHttpBinding"
- contract="MessageInspectorDemo.ICalculator"/>
- < /service>
- < /services>
- < behaviors>
- < serviceBehaviors>
- < behavior name="messageInspectorBehavior">
- < myBehaviorExtensionElement providerName="Test"/>
- < /behavior>
- < /serviceBehaviors>
- < /behaviors>
- < extensions>
- < behaviorExtensions>
- < add name="myBehaviorExtensionElement"
- type="MessageInspectorDemo.MyBehaviorExtensionElement,
MessageInspectorDemo,
Version=1.0.0.0, Culture=neutral, PublicKeyToken=null"/>- < /behaviorExtensions>
- < /extensions>
- < /system.serviceModel>
- < /configuration>
注意,在< serviceBehaviors>一節(jié)中,< behavior>下的< myBehaviorExtensionElement>就是我們擴(kuò)展的行為,providerName則是 MyBehaviorExtensionElement增加的屬性。如果擴(kuò)展了IEndpointBehavior,則配置節(jié)的名稱為< endpointBehaviors>。< extensions>節(jié)負(fù)責(zé)添加自定義行為的擴(kuò)展。其 中,< add>中的name值與< behavior>下 的< myBehaviorExtensionElement>對(duì)應(yīng)。
在對(duì)WCF行為類型操作時(shí),特別注意的是< extensions>下的 type值,必須是類型的full name。第一個(gè)逗點(diǎn)前的內(nèi)容為完整的類型名(包括命名空間),第二部分為完整的命名空間。Version,Culture以及 PublicKeyToken也是缺一不可的。每個(gè)逗點(diǎn)后必須保留一個(gè)空格,否則無(wú)法正確添加擴(kuò)展行為的配置。這與反射有關(guān),但太容易讓人忽略這一小細(xì)節(jié)。希望微軟能在后來(lái)的版本中修訂這個(gè)瑕疵。