EF webapi json序列化 表间相互引用 无限循环问题解决方案

 

WebApiConfig.cs中加入 如下代码即可解决无限循环问题

            var json = config.Formatters.JsonFormatter;
            // 解决json序列化时的循环引用问题
            json.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;
            // 干掉XML序列化器
            config.Formatters.Remove(config.Formatters.XmlFormatter);

另外还有一个问题就是ef 如果用到 lazy加载的话, 输出的ef实体 会将关联表数据 都输出出来,解决方案是:

1.将没用的字段置空

2.用动态类型输出,例如: return  new{xx=user.userId,yy=...}

3.将virtual属性标记为 忽略输出json(可通过ef tt模板实现)

using Newtonsoft.Json;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Runtime.Serialization;
using System.Web;
using System.Xml.Serialization;

namespace CircularReferenceSample.Models
{
    // Fix 3
    [JsonObject(IsReference = true)]
    public class Category
    {
        public int Id { get; set; }
        public string Name { get; set; }

        // Fix 3
        //[JsonIgnore]
        //[IgnoreDataMember]
        public virtual ICollection<Product> Products { get; set; }
    }

    [DataContract(IsReference = true)]
    public class Product
    {
        [Key]
        public int Id { get; set; }

        [DataMember]
        public string Name { get; set; }

        [DataMember]
        public virtual Category Category { get; set; }
    }
}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值