Sérialisation ServiceStack JSON : conservation des informations de type dans l'héritage
La sérialisation JSON de ServiceStack nécessite un examen attentif de la gestion des types pour éviter la corruption des données. Illustrons cela avec un exemple :
<code class="language-csharp">public class Container { public Animal Animal { get; set; } } public class Animal { } public class Dog : Animal { public void Speak() { Console.WriteLine("Woof!"); } } var container = new Container { Animal = new Dog() }; var json = JsonSerializer.SerializeToString(container); var container2 = JsonSerializer.DeserializeFromString<Container>(json); ((Dog)container.Animal).Speak(); // Works ((Dog)container2.Animal).Speak(); // InvalidCastException</code>
Ce code met en évidence un problème courant de désérialisation : le type Dog
est perdu après la sérialisation JSON. Le JSON standard manque d’informations de type inhérentes.
ServiceStack résout ce problème en étendant JSON avec une propriété __type
. Cela agit comme un identifiant de type, permettant une désérialisation correcte des types hérités. Cependant, ServiceStack n'ajoute cette propriété que lorsque cela est nécessaire (interfaces, objets à liaison tardive, classes abstraites).
Pour conserver le type Dog
, refactorisez Animal
en tant qu'interface ou classe abstraite :
<code class="language-csharp">public interface IAnimal // Interface { } public abstract class Animal // Abstract class { }</code>
Cependant, il est généralement recommandé d'éviter l'héritage dans les objets de transfert de données (DTO) :
__type
compromettent l'interopérabilité.En utilisant la propriété __type
judicieusement et en suivant ces bonnes pratiques, ServiceStack garantit une désérialisation précise des types hérités tout en optimisant la vitesse et la flexibilité de la sérialisation.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!