Lors de l'analyse des données JSON, il est essentiel de gérer les scénarios dans lesquels les valeurs d'énumération fournies ne correspondent pas à celles définies dans votre base de code. Cela se produit généralement lorsque des API tierces introduisent de nouvelles valeurs d'énumération au fil du temps.
Solution : JsonConverter personnalisé
Pour résoudre ce problème, vous pouvez créer un JsonConverter personnalisé :
class TolerantEnumConverter : JsonConverter { // ... Implementation ... }
Ce convertisseur simplifie le processus de désérialisation avec les éléments suivants logique :
Exemple d'utilisation :
[JsonConverter(typeof(TolerantEnumConverter))] enum Status { Ready, Set, Go } string json = @"{ ""status"": ""SomethingElse"" }"; var status = JsonConvert.DeserializeObject<Status>(json); // Returns "Ready"
Énumérations nullables et valeurs "inconnues" :
Pour gérer les énumérations nullables avec des valeurs inconnues, vous pouvez ajouter une valeur « Inconnu » à votre définition d'énumération. Par exemple :
[JsonConverter(typeof(TolerantEnumConverter))] enum Color { Red, Yellow, Green, Unknown = 99 } string colorJson = @"{ ""color"": ""Purple"" }"; var color = JsonConvert.DeserializeObject<Color?>(colorJson); // Returns null
Conclusion :
En utilisant le JsonConverter personnalisé présenté ici, vous pouvez garantir que la désérialisation JSON se déroule sans problème même lorsque les valeurs d'énumération changent au fil du temps, prévenir les erreurs et maintenir l’intégrité des données.
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!