WCF无法序列化循环引用

WCF can#39;t serialize cyclic references(WCF无法序列化循环引用)
本文介绍了WCF无法序列化循环引用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个数据库,在TablesSilverlight客户端之间有许多关系,该客户端通过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无法序列化循环引用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)