序列化类型为“****”的对象时检测到循环引用。

it2022-05-09  34

问题:

2个类:MetaSet和MetaObject,为1:N的关系。

在Asp.net mvc2.0下,返回Json数据时,出现“序列化类型为“DataCenter.Core.Domain.MetaSet”的对象时检测到循环引用。”

Mvc代码如下:

IList<MetaSet> sets = new List<MetaSet>(); sets = _metaSetRepository.GetMetaSetByParentTreeCodeID(treeCodeID, CheckState.yes); if (Request.IsAjaxRequest()) { return new JsonResult { Data =sets, JsonRequestBehavior= JsonRequestBehavior.AllowGet }; }

数据操作代码如下:

public IList<MetaSet> GetMetaSetByParentTreeCodeID(string treeCodeID, CheckState state) { var query = Session.CreateQuery(@" select m from MetaSet m where m.TreeCode like :treecodeid and m.IsDelete=False and m.CheckState=:checkState order by m.TreeCode asc") .SetString("treecodeid", treeCodeID + "%").SetEnum("checkState", state); return query.List<MetaSet>(); }

原因:

  在MVC里面返回一个json对象的数据,在这个过程中将我们找到的这条数据进行序列化为json对象的一个过程。在这个过程的时候,由于这个对象有映射 关系,那么它在序列化MetaSet对象的时候会序列化该对象的属性MetaObject对象,而这个属性MetaObject对象又有属性MetaSet对象,依次反复。就导致了这个问题的产生。

解决方案:

规避json序列化的时候直接序列化该MetaSet对象,改为序列化不带这种映射关系的对象;

public IList<MetaSet> GetMetaSetByParentTreeCodeID2(string treeCodeID, CheckState state) { var query = Session.CreateQuery(@" select new MetaSet(m.MetaSetID,m.Name,m.ParentID,m.ControllerAction) from MetaSet m where m.TreeCode like :treecodeid and m.IsDelete=False and m.CheckState=:checkState order by m.TreeCode asc") .SetString("treecodeid", treeCodeID + "%").SetEnum("checkState", state);return query.List<MetaSet>(); }

参考:

http://archive.cnblogs.com/a/1956117/

转载于:https://www.cnblogs.com/lzm525/archive/2011/10/18/2216114.html

相关资源:数据结构—成绩单生成器

最新回复(0)