Lorsque vous travaillez avec des sockets Web et que vous rencontrez des erreurs, il est souvent nécessaire de transmettre des messages d'erreur. Au départ, l'utilisation de JSON.stringify semble être une solution simple, mais elle ne chaîne pas correctement les objets Error natifs.
Problème :
Tentative de chaîner les résultats d'un objet Error. dans un objet vide ({}), indiquant que les informations de l'erreur n'étaient pas capturé.
Cause :
Le problème réside dans les propriétés du prototype de l'objet Erreur. Les propriétés clés telles que la pile et le message ont leur indicateur énumérable défini sur false. Par conséquent, JSON.stringify ignore ces propriétés lors du processus de sérialisation, vous laissant avec un objet vide.
Solution :
Pour contourner ce comportement, il est nécessaire d'extraire manuellement les propriétés de l'objet Error à l'aide de Object.getOwnPropertyNames. Ces propriétés peuvent ensuite être transmises à JSON.stringify en tant que fonction de remplacement pour créer une chaîne JSON incluant les informations sur l'erreur :
JSON.stringify(err, Object.getOwnPropertyNames(err))
Vous pouvez également créer vos propres objets d'erreur personnalisés avec des propriétés énumérables, leur permettant d'être stringifiés correctement par JSON.stringify.
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!