全面分析WCF KnownType
WCF經過長時間的發展,很多用戶都很了解WCF了,這里我發表一下個人理解,和大家討論討論。大家請注意ClassWillProcessl類型,我們需要增加哪些類型到KnownType中呢?如果我們在應用中可能將ClassB的實例賦值給ca的話,我們需要增加ClassB到KnowType中([KnowType(typeof(ClassB))]),因為ClassB派生于ClassA,所以在反序列化時存在向下造型。如果不存在這種可能性的話,可以不加。
#T#由于ia的聲明類型是一個接口,所以我們需要將接口的實現類加到WCF KnownType中。在這里是ImplA和ImplB。試想一下,如果我們只增加了ImplA到KnownType中,并且我們將ImplB的實例賦給了ia,反序列化引擎還是會將其反序列化成ImplA,因為它只知道ImplA.如果我們arraylist1集合中可能會將ClassC和ClassD放入其中,由于非泛型集合都是使用Object來保存實際對象,所以我們也需要將ClassC和ClassD加入到WCF KnownType中。如果我們也希望將一個int的數組存放在numberValue中(當然在實際情況中很少發生),我么也需要將int[]加入到WCF KnownType中。
增加了KnownType的ClassWillProcessl類型如下:
- [DataContract]
- [KnowType(typeof(ClassB))]
- [KnowType(typeof(ImplA))]
- [KnowType(typeof(ImplB))]
- [KnowType(typeof(ClassC))]
- [KnowType(typeof(ClassD))]
- [KnowType(typeof(int[]))]
- Public class ClassWillProcess
- {
- [DataMember]
- ClassA ca;
- [DataMember]
- InterfaceA ia;
- [DataMember]
- ArrayList arraylist1;
- Object numberValue;
- [DataMember]
- Public object Numbers
- {
- get {return numberValue;}
- set {numberValue=value;}
- }
- }