今天在做MVC项目的时候,由于需要将对象转换为Json值,使用的代码如下:
public ActionResult QuaryOrders()
{
var dataOrder = db.OrderDetails.Include(n => n.Product);
return Json(dataOrder, JsonRequestBehavior.AllowGet);
}
但EF提示“序列化类型为XXX的对象时检测到循环引用”,截图如下:
产生这种的原因是Entity Framework两个模型之间进行了相互引用,就是说这两个在数据中的表有主外键关系的
解决方法有两种:
方法一:使用匿名类来传递对象:
public ActionResult QuaryOrders()
{
var dataOrder = db.OrderDetails.Include(n => n.Product).Select(n => new { Id=n.Id ,OrderId = n.OrderId});
return Json(dataOrder, JsonRequestBehavior.AllowGet);
}
方法二:使用命名空间Newtonsoft.Json(该程序集可以使用Nuget来下载)中的方法来序列化Json对象,转换后对数据会包含转义字符“\”:
public ActionResult QuaryOrders()
{
JsonSerializerSettings setting = new JsonSerializerSettings()
{
ReferenceLoopHandling = ReferenceLoopHandling.Ignore,
Formatting = Formatting.None
};
var ret = JsonConvert.SerializeObject(dataOrder, setting);
return Json(ret, JsonRequestBehavior.AllowGet);
}
补充:MVC中使用JSON的时候(考虑运行Get请求方式和导航属性造成的循环引用),在使用Get请求的使用要使用Json(ret, JsonRequestBehavior.AllowGet)方法,而由于导航属性造成的循环引用应该首先考虑使用匿名内部类来解决,也可以使用Json序列化工具Newtonsoft.Json中决序列化的循环引用问题,本文着重描述使用匿名内部类解决,其他方法可以上网搜索,谢谢!