本文介绍了WCF无法序列化循环引用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个数据库,在Tables
和Silverlight
客户端之间有许多关系,该客户端通过ASP.Net
端的WCF service
连接到我的服务器。
首先,我使用LINQ to SQL
作为对象的健壮映射表,并在WebMethod
中返回数据库对象的List<Foo>
(假设GetFoo()
)。Foo
与其他对象有很多关系,每个对象也有很多realaship(这意味着表之间有PK和FK)。我还使用Microsoft Service Trace Viewr
来跟踪我的服务
当我调用GetFoo()时,WCF返回以下错误:
类型‘X.Y.Z’的对象图包含循环,如果满足以下条件,则无法序列化 引用跟踪已禁用
我搜索了此错误,找到this great post,但工作不正常,我也看到了相同的错误。
推荐答案
各种选项:
- 从模型中删除循环依赖项;对于生成的模型来说,这可能会很棘手,因为生成的模型有很多针对它构建的现有代码,但值得尝试;但是,您通常不希望序列化父,这正是LINQ-to-SQL希望您保留的(它将允许您删除子属性,但这是您通常希望序列化的)
- 启用循环引用;看起来您尝试过但没有成功;不过,您是否在两端都启用了?事实上,如果Silverlight不喜欢这个扩展(它对扩展的支持有限) ,我也不会感到惊讶
- 使用单独的(平面)DTO模型进行数据传输
- 尝试使用NetDataContractSerializer;我不记得Silverlight是否支持它,我必须承认我不是它的忠实粉丝,但它在这里可能是一个实用的修复
我坚定地选择"DTO模型";简单地说,拥有一个单独的模型意味着您在调整数据库时不太可能遇到麻烦--并且您完全可以控制它。
这篇关于WCF无法序列化循环引用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!