给学生上课:
public class Parent
{
public int id {get; set;}
public int name {get; set;}
public virtual ICollection<Child> children {get; set;}
}
[Table("Child")]
public partial class Child
{
[Key]
public int id {get; set;}
public string name { get; set; }
[NotMapped]
public string nickName { get; set; }
}控制器代码:
List<Parent> parents = parentRepository.Get();
return Json(parents); 它在本地主机上工作,但在活动服务器上不工作:
错误:Json在序列化类型的对象时检测到循环引用
我搜索并找到了[ScriptIgnore]属性,所以我将模型更改为
using System.Web.Script.Serialization;
public class Parent
{
public int id {get; set;}
public int name {get; set;}
[ScriptIgnore]
public virtual ICollection<Child> children {get; set;}
}但是在活动服务器(win2008)上也会发生同样的错误。
如何避免该错误并成功地序列化父数据?
发布于 2013-01-29 21:53:13
尝试以下代码:
return Json(
parents.Select(x => new {
id = x.id,
name = x.name,
children = x.children.Select(y => new {
// Assigment of child fields
})
})); 如果只需要父属性,则为...or:
return Json(
parents.Select(x => new {
id = x.id,
name = x.name
})); 这并不是真正解决这个问题的方法,但是在序列化DTO时,这是一个常见的解决方法.
发布于 2013-08-06 21:41:26
我有一个类似的问题,同样,我也无法解决根本的问题。我认为服务器正在使用与本地主机不同的dll来通过json.encode将json转换为json。
我把这个问题和我的决议发到这里了,A circular reference was detected while serializing with Json.Encode
我和割风商量好了。
发布于 2016-09-18 10:36:31
您可以使用此代码而不使用select扩展函数来筛选列。
var list = JsonConvert.SerializeObject(Yourmodel,
Formatting.None,
new JsonSerializerSettings() {
ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore
});
return list;https://stackoverflow.com/questions/14592781
复制相似问题