Compartilhar via


SYSLIB0049: JsonSerializerOptions.AddContext está obsoleto

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

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

Solução alternativa

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ê prepare ou anexe resolvedores em vários sites de chamada. Ele também permite que você introspecte a cadeia ou remova componentes dela.

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

Suprimir um aviso

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

Para suprimir apenas uma violação única, adicione as diretivas de pré-processador ao arquivo de origem para desabilitar e, em seguida, reabilite 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 avisos SYSLIB0049 no projeto, adicione uma propriedade <NoWarn> ao arquivo de projeto.

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

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