Я использую odata (microsoft.aspnetcore.odata) и openapi (microsoft.aspnetcore.openapi), поэтому я использую свои типы объектов непосредственно на конечных точках со ссылками, это причина, которая не работает на ошибке »>
JsonReaderException: The maximum configured depth of 64 has been exceeded. Cannot read next JSON object. LineNumber: 0 | BytePositionInLine: 45889.
System.Text.Json.ThrowHelper.ThrowJsonReaderException(ref Utf8JsonReader json, ExceptionResource resource, byte nextByte, ReadOnlySpan bytes)
< /code>
Я знаю, что использование DTOS без ссылки на цикл может исправить это, но я не могу сделать это, потому что мне нужно, чтобы Odata может получить доступ к свойствам навигации. Разоблачить iqueryable с помощью запроса включения, конечные точки работают нормально, но OpenAPI на /пенапи /в1.json выходит из строя с максимальной настройкой глубины 64. Если я изменю максимальную глубину, это не будет иметь значения, потому что ссылка на цикл доходит до бесконечного.[ApiController]
[Route("/odata/books")]
public class BookController(ApplicationDbContext db) : ODataController
{
[EnableQuery]
[HttpGet]
public IQueryable Get()
{
return db.Books;
}
}
< /code>
public class Book
{
public Guid Id { get; set; }
public string Title { get; set; }
public string Description { get; set; }
public Author Author { get; set; }
public Guid AuthorId { get; set; }
}
public class Author
{
public Guid Id { get; set; }
public string Name { get; set; }
public DateOnly Birthdate { get; set; }
public string Nationality { get; set; }
// cycle reference
public List Books { get; set; } = [];
}
< /code>
Я не могу использовать DTO, потому что мне нужны полные отношения с Odata, как
/odata/books?$expand=author($select=name)
Я использую odata (microsoft.aspnetcore.odata) и openapi (microsoft.aspnetcore.openapi), поэтому я использую свои типы объектов непосредственно на конечных точках со ссылками, это причина, которая не работает на ошибке »>[code]JsonReaderException: The maximum configured depth of 64 has been exceeded. Cannot read next JSON object. LineNumber: 0 | BytePositionInLine: 45889. System.Text.Json.ThrowHelper.ThrowJsonReaderException(ref Utf8JsonReader json, ExceptionResource resource, byte nextByte, ReadOnlySpan bytes) < /code> Я знаю, что использование DTOS без ссылки на цикл может исправить это, но я не могу сделать это, потому что мне нужно, чтобы Odata может получить доступ к свойствам навигации. Разоблачить iqueryable с помощью запроса включения, конечные точки работают нормально, но OpenAPI на /пенапи /в1.json выходит из строя с максимальной настройкой глубины 64. Если я изменю максимальную глубину, это не будет иметь значения, потому что ссылка на цикл доходит до бесконечного.[ApiController] [Route("/odata/books")] public class BookController(ApplicationDbContext db) : ODataController { [EnableQuery] [HttpGet] public IQueryable Get() { return db.Books; } } < /code> public class Book { public Guid Id { get; set; }
public string Title { get; set; }
public string Description { get; set; }
public Author Author { get; set; }
public Guid AuthorId { get; set; } }
public class Author { public Guid Id { get; set; }
public string Name { get; set; }
public DateOnly Birthdate { get; set; }
public string Nationality { get; set; }
// cycle reference public List Books { get; set; } = []; } < /code> Я не могу использовать DTO, потому что мне нужны полные отношения с Odata, как /odata/books?$expand=author($select=name)[/code]