Como habilitar a correspondência de nomes de propriedade que não diferenciam maiúsculas de minúsculas com System.Text.Json

Neste artigo, você aprenderá a habilitar a correspondência de nome de propriedade que não diferencia maiúsculas de minúsculas com o namespace System.Text.Json.

Correspondência de propriedades que não diferencia maiúsculas de minúsculas

Por padrão, a desserialização procura correspondências de nome de propriedade que diferenciam maiúsculas de minúsculas entre o JSON e as propriedades do objeto alvo. Para alterar esse comportamento, defina JsonSerializerOptions.PropertyNameCaseInsensitive como true:

Observação

O padrão da Web não diferencia maiúsculas de minúsculas.

var options = new JsonSerializerOptions
{
    PropertyNameCaseInsensitive = true
};
WeatherForecast? weatherForecast = JsonSerializer.Deserialize<WeatherForecast>(jsonString, options);
Dim options As JsonSerializerOptions = New JsonSerializerOptions With {
    .PropertyNameCaseInsensitive = True
}
Dim weatherForecast1 = JsonSerializer.Deserialize(Of WeatherForecast)(jsonString, options)

Aqui está o exemplo JSON com nomes de propriedade em minúsculas concatenadas. Ele pode ser desserializado no tipo a seguir que tem nomes de propriedade em Pascal case.

{
  "date": "2019-08-01T00:00:00-07:00",
  "temperatureCelsius": 25,
  "summary": "Hot",
}
public class WeatherForecast
{
    public DateTimeOffset Date { get; set; }
    public int TemperatureCelsius { get; set; }
    public string? Summary { get; set; }
}
Public Class WeatherForecast
    Public Property [Date] As DateTimeOffset
    Public Property TemperatureCelsius As Integer
    Public Property Summary As String
End Class

Confira também