我可以将WCF DataContract添加到复杂类型吗?
我有一个复杂的数据类型,包括许多函数,以及通常的get和get方法。 如果我可以使用WCF,我的生活会变得相当容易,所以我的客户也可以使用这种数据类型。
我
-
忽略所有操作,仅在需要的地方放置
[DataMemeber]
。 -
将有问题的类放在共享库程序集中,以供客户端和服务器访问。
谢谢,罗伯托
PS。 我意识到这个问题的措辞可能不尽如人意。
所有通过WCF边界传输的都是序列化的 – 这相当于类的状态。 方法不会。 因此,如果您需要双方都可以使用它们,那么您需要一个共享库。
添加服务引用时,可以选择重用数据类型,在这种情况下,WCF将反序列化为共享类,并使用方法。 但它只是实际跨越边界传递的字段值。
好吧,结果certificate是所有上述答案的组合。
- 将数据类粘贴到共享程序集中,从客户端和服务器项目引用。
- 确保在“配置服务引用”对话框中选中了“参考程序集中的重用类型”项。
- 在每个数据合同开始时,输入[KnownType]属性。
代码如下:
[DataContract] [KnownType(typeof(WHS2SmugmugShared.Photo))] [KnownType(typeof(WHS2SmugmugShared.PhotoInfo))] public class Photo { //code here }
在上面的例子中,我在Photo类中使用PhotoInfo。 PhotoInfo在类文件中没有与之关联的KnownType属性。 而且似乎并不需要。
这允许您序列化复杂类型但仍保持其操作。
数据合同的最佳实践是将其作为合同 – 仅在没有行为的情况下生成数据。 第二个最佳实践是使用[DataMember]装饰您的类,并将其保留在服务器上 – 让客户端使用代理副本。
简短回答:是的。 WCF处理像champ这样的复杂类型。 传递复杂类型时,您只想关注传递的数据。 如果您的客户端不共享DLL,则仅关注传递的数据(而不是任何其他操作)变得更加重要,因为客户端将只获取复杂类型的数据成员的副本。
我猜你来自Java背景? 使用WCF,您需要使用DataMember属性标记字段,或者(更好)将get / set方法更改为属性。
例如,而不是:
[DataContract] public class Foo { [DataMember] private string bar; public string GetBar() { return bar; } public void SetBar(string b) { bar = b; } }
您可以使用以下内容:
[DataContract] public class Foo { [DataMember] public string Bar { get; set; } }
使用可序列化属性装饰所有此类类型。因此,您不需要为参与WCF服务的每个复杂类放置[DataContract]属性。
在WCF客户端添加包含thoes类型的dll,让代理重用这些类,而不是重新生成deserilization所需的类。 如果添加任何类型intoproxy删除它并使用从DLL。 通过这种方式,我可以轻松地分享我的复杂类型。 但它只适用于你可以将你的类型作为单独的dll sh。