SYSLIB0049: element JsonSerializerOptions.AddContext jest przestarzały

Metoda JsonSerializerOptions.AddContext<TContext>() jest przestarzała, począwszy od platformy .NET 8. Wywołanie go w kodzie generuje ostrzeżenie SYSLIB0049 w czasie kompilacji.

Metoda JsonSerializerOptions.AddContext<TContext>() została wprowadzona na platformie .NET 6 jako środek do skojarzenia JsonSerializerOptions wystąpień z określonym JsonSerializerContext typem. Ta metoda została w dużej mierze zastąpiona na platformie .NET 7 wraz z wprowadzeniem dostosowywania kontraktu TypeInfoResolver i właściwością.

Rozwiązanie

Zamiast tego użyj jednej z następujących właściwości:

  • TypeInfoResolver — Ta właściwość umożliwia dodanie jednego lub wielu elementów rozpoznawania jednocześnie.
  • TypeInfoResolverChain — Ta właściwość umożliwia wstępne lub dołączanie rozpoznawania nazw w wielu lokacjach wywołań. Umożliwia również introspekcja łańcucha lub usunięcie z niego składników.

Aby uzyskać więcej informacji, zobacz Łączenie generatorów źródeł.

Pomijanie ostrzeżenia

Jeśli musisz używać przestarzałych interfejsów API, możesz pominąć ostrzeżenie w kodzie lub w pliku projektu.

Aby pominąć tylko jedno naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć ostrzeżenie.

// Disable the warning.
#pragma warning disable SYSLIB0049

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0049

Aby pominąć wszystkie SYSLIB0049 ostrzeżenia w projekcie, dodaj <NoWarn> właściwość do pliku projektu.

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0049</NoWarn>
  </PropertyGroup>
</Project>

Aby uzyskać więcej informacji, zobacz Pomijanie ostrzeżeń.