Partilhar via


SYSLIB0049: JsonSerializerOptions.AddContext está obsoleto

O JsonSerializerOptions.AddContext<TContext>() método está obsoleto, começando no .NET 8. Chamá-lo em código gera aviso SYSLIB0049 em tempo de compilação.

O JsonSerializerOptions.AddContext<TContext>() método foi introduzido no .NET 6 como um meio de associar JsonSerializerOptions instâncias a um tipo especificado JsonSerializerContext . Esse método foi amplamente substituído no .NET 7 com a introdução da personalização do contrato e da TypeInfoResolver propriedade.

Solução

Em vez disso, use uma das seguintes propriedades:

  • TypeInfoResolver - Esta propriedade permite adicionar um ou vários resolvedores de uma só vez.
  • TypeInfoResolverChain - Esta propriedade permite que você anexe ou anexe resolvedores em vários locais de chamada. Ele também permite introspeccionar a cadeia ou remover componentes dela.

Para obter mais informações, consulte Combinar geradores de origem.

Suprimir um aviso

Se você precisar usar as APIs obsoletas, poderá suprimir o aviso no código ou no arquivo de projeto.

Para suprimir apenas uma única violação, adicione diretivas de pré-processador ao arquivo de origem para desativar e reativar o aviso.

// Disable the warning.
#pragma warning disable SYSLIB0049

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

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

Para suprimir todos os SYSLIB0049 avisos em seu projeto, adicione uma <NoWarn> propriedade ao seu arquivo de projeto.

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

Para obter mais informações, consulte Suprimir avisos.