JsonException: A possible object cycle was detected which is not supported. This can either be due to a cycle or if the object depth is larger than

后端 未结 6 930
执念已碎
执念已碎 2021-02-04 16:07

In my web api when i run project for get data from database got this error .net core 3.1

JsonException: A possible object cycle was detected which is not

6条回答
  •  野的像风
    2021-02-04 16:42

    this is happening because your data have a reference loop.

    e.g

    // this example creates a reference loop
    var p = new Product()
         { 
            ProductCategory = new ProductCategory() 
               { products = new List() }
         };
        p.ProductCategory.products.Add(p); // <- this create the loop
        var x = JsonSerializer.Serialize(p); // A possible object cycle was detected ...
    

    You can not handle the reference loop situation in the new System.Text.Json yet (netcore 3.1.1) unless you completely ignore a reference and its not a good idea always. (using [JsonIgnore] attribute)

    but you have two options to fix this.

    1. you can use Newtonsoft.Json in your project instead of System.Text.Json (i linked an article for you)

    2. Download the System.Text.Json preview package version 5.0.0-alpha.1.20071.1 from dotnet5 gallery (through Visual Studio's NuGet client):

    option 1 usage:

    services.AddMvc()
         .AddNewtonsoftJson(
              options => {
               options.SerializerSettings.ReferenceLoopHandling = ReferenceLoopHandling.Ignore; 
          });
    // if you not using .AddMvc use these methods instead 
    //services.AddControllers().AddNewtonsoftJson(...);
    //services.AddControllersWithViews().AddNewtonsoftJson(...);
    //services.AddRazorPages().AddNewtonsoftJson(...);
    

    option 2 usage:

    // for manual serializer
    var options = new JsonSerializerOptions
    {
        ReferenceHandling = ReferenceHandling.Preserve
    };
    
    string json = JsonSerializer.Serialize(objectWithLoops, options);
    
    // -----------------------------------------
    // for asp.net core 3.1 (globaly)
     services.AddMvc()
      .AddJsonOptions(o => {
         o.JsonSerializerOptions
           .ReferenceHandling = ReferenceHandling.Preserve  
                });
    

    these serializers have ReferenceLoopHandling feature.


    but if you decide to just ignore one reference use [JsonIgnore] on one of these properties. but it causes null result on your API response for that field even when you don't have a reference loop.

    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string ProductText { get; set; }
    
        public int ProductCategoryId { get; set; }
        // [JsonIgnore] HERE or
        public virtual ProductCategory ProductCategory { get; set; }
    }
    
    public class ProductCategory
    {
        public int Id { get; set; }
        // [JsonIgnore] or HERE
        public ICollection products {get;set;}
    }
    

提交回复
热议问题