SYSLIB0049: JsonSerializerOptions.AddContext は廃止されています

.NET 8 以降、JsonSerializerOptions.AddContext<TContext>() メソッドは廃止されました。 それをコードで呼び出すと、コンパイル時に警告 SYSLIB0049 が生成されます。

この JsonSerializerOptions.AddContext<TContext>() メソッドは、指定した JsonSerializerContext 型に JsonSerializerOptions インスタンスを関連付ける手段として.NET 6 で導入されました。 このメソッドは、コントラクトのカスタマイズTypeInfoResolver プロパティの導入により、.NET 7 でほとんど置き換えられました。

回避策

代わりに、次のいずれか 1 つのプロパティを使用してください。

  • TypeInfoResolver - このプロパティを使用すると、1 つ以上のリゾルバーを一度に追加できます。
  • TypeInfoResolverChain - このプロパティを使用すると、複数の呼び出しサイトでリゾルバーを先頭または末尾に追加できます。 チェーンの検証や、そこからのコンポーネントの削除も行うことができます。

詳細については、「ソース ジェネレーターを結合する」を参照してください。

警告を抑制する

古い API を使う必要がある場合は、コードまたはプロジェクト ファイルで警告を抑制することができます。

単一の違反だけを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して警告を無効にしてから、再度有効にします。

// Disable the warning.
#pragma warning disable SYSLIB0049

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

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

プロジェクトですべての SYSLIB0049 警告を抑制するには、プロジェクト ファイルに <NoWarn> プロパティを追加します。

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

詳細については、「警告を表示しない」を参照してください。