Dépannage des erreurs de boucle d'auto-référence JSON.net
Sérialisation des classes POCO complexes (anciens objets CLR simples), en particulier ceux générés à partir de modèles de données d'entité (.edmx), en utilisant JsonConvert.SerializeObject
peut parfois conduire à une erreur "de boucle d'auto-référence détectée". Cela se produit parce que les références circulaires dans le modèle créent une boucle infinie pendant la sérialisation.
Résolution des références circulaires
La solution consiste à configurer le processus de sérialisation à l'aide de JsonSerializerSettings
. Plus précisément, la propriété ReferenceLoopHandling
offre plusieurs options:
ReferenceLoopHandling.Error
(par défaut): lance une exception lors de la rencontre d'une référence circulaire. Ceci est la source de l'erreur. ReferenceLoopHandling.Serialize
: Sérialise les objets imbriqués, mais empêche la récursivité infinie. ReferenceLoopHandling.Ignore
: saute la sérialisation d'objets qui sont leurs propres enfants. Pour ignorer les boucles d'auto-référence, utilisez ce code:
JsonConvert.SerializeObject(YourPOCO, Formatting.Indented, new JsonSerializerSettings { ReferenceLoopHandling = ReferenceLoopHandling.Ignore });
Pour les scénarios avec des objets d'auto-références profondément imbriqués, utilisez la propriété PreserveReferencesHandling
:
JsonConvert.SerializeObject(YourPOCO, Formatting.Indented, new JsonSerializerSettings { PreserveReferencesHandling = PreserveReferencesHandling.Objects });
Choisir le paramètre approprié dépend de votre structure de données. Sélectionnez la méthode qui gère le mieux les relations de votre objet pour éviter les erreurs et assurer une sérialisation correcte.
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!