Negli script #563 e #565 abbiamo visto alcune tecniche per gestire il polimorfismo durante la fase di serializzazione di un oggetto utilizzando la libreria System.Text.Json. Tutti questi approcci prevedevano l'uso delle funzionalità integrate della libreria. In questo script analizziamo invece una funzionalità che ci permette di alterare il modo in cui la libreria serializza un oggetto e quind grazie alla quale possiamo gestire manualmente il processo di serializzazione: i converter.
Per creare un converter dobbiamo creare una classe che eredita da JsonConverter<T> dove T è la classe base della gerarchia per cui creiamo il converter. Una volta creata la classe, dobbiamo eseguire l'override della proprietà CanConvert e dei metodi Read (usato per deserializzare l'oggetto) e Write (usato per serializzare l'oggetto).
public class Vehicle { public string Name { get; set; } } public class Car : Vehicle { public int Doors { get; set; } } public class Train : Vehicle { public int Coaches { get; set; } } public class VehicleConverter : JsonConverter<Vehicle> { public override bool CanConvert(Type typeToConvert) => typeof(Vehicle).IsAssignableFrom(typeToConvert); public override Vehicle Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) { throw new NotImplementedException(); } public override void Write(Utf8JsonWriter writer, Vehicle vehicle, JsonSerializerOptions options) { writer.WriteStartObject(); if (vehicle is Car c) { writer.WriteNumber(nameof(c.Doors), c.Doors); } else if (vehicle is Train t) { writer.WriteNumber(nameof(t.Coaches), t.Coaches); } writer.WriteString(nameof(vehicle.Name), vehicle.Name); writer.WriteEndObject(); } }
La proprietà CanConvert torna true se l'oggetto passato in input eredita da Vehicle, mentre il metodo Read è commentato perché ne parleremo in un prossimo script. Il metodo su cui ci concentriamo è Write il quale prende in input l'oggetto Vehicle e il writer in cui scrivere i dati. All'interno del metodo verifichiamo il tipo dell'oggetto in input e scriviamo nel writer le relative proprietà.
Per utilizzare il converter durante la serializzazione, dobbiamo creare un oggetto JsonSerializerOptions, aggiungerci il converter e passare l'oggetto al metodo Serialize.
var c = new Car { Doors = 2, Name = "mycar" }; var serializeOptions = new JsonSerializerOptions(); serializeOptions.Converters.Add(new VehicleConverter()); Console.WriteLine(JsonSerializer.Serialize(c, serializeOptions));
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Controllare gli accessi IP alle app con Azure Container Apps
Installare le Web App site extension tramite una pipeline di Azure DevOps
Migrare una service connection a workload identity federation in Azure DevOps
Usare le collection expression per inizializzare una lista di oggetti in C#
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
Potenziare Azure AI Search con la ricerca vettoriale
Eseguire una query su SQL Azure tramite un workflow di GitHub
Utilizzare Tailwind CSS all'interno di React: primi componenti
Gestire i null nelle reactive form tipizzate di Angular
Verificare la provenienza di un commit tramite le GitHub Actions
Evitare la command injection in un workflow di GitHub
Generare token per autenicarsi sulle API di GitHub