


Créer un système de gestion des erreurs simple et efficace dans Node.js
Nov 30, 2024 pm 03:29 PMLors de la création d’applications Web, les choses ne se passent pas toujours comme prévu. Les utilisateurs peuvent tenter des opérations non valides, des données peuvent être manquantes ou des bogues inattendus peuvent survenir. La gestion gracieuse de ces erreurs est essentielle pour créer une application fiable et offrir une bonne expérience utilisateur.
Dans cet article, je vais vous montrer comment implémenter un système de gestion des erreurs simple et efficace dans votre application Node.js. Allons-y?! ?
Les bases de la gestion des erreurs
En JavaScript, une erreur est généralement représentée comme une instance de la classe Error. Lorsque quelque chose ne va pas, vous pouvez ? générer ? une erreur et votre application peut la détecter pour répondre en conséquence. Cependant, dans les applications plus volumineuses, la gestion des erreurs avec uniquement la classe Error de base peut s'avérer compliquée.
C'est là que les classes d'erreur personnalisées sont utiles?!
Création d'une classe d'erreur personnalisée
Voici une classe appelée AppError que nous pouvons utiliser pour définir des erreurs structurées et significatives?:
export class AppError extends Error { constructor(name, httpCode, description, isOperational, errors = []) { super(description); // Call the parent class (Error) constructor this.name = name; // Name of the error (e.g., ValidationError) this.httpCode = httpCode; // HTTP status code (e.g., 400, 404, 500) this.isOperational = isOperational; // Flag to distinguish between operational and system errors this.errors = errors; // Optional array of detailed error messages } }
Comment ?a marche ?
- nom?: décrit le type d'erreur, comme ValidationError ou NotFoundError.
- httpCode?: définit un code d'état HTTP approprié, tel que 400 pour les requêtes incorrectes ou 500 pour les erreurs du serveur.
- description?: fournit un message convivial décrivant l'erreur.
- isOperational?: un indicateur booléen pour indiquer si l'erreur était attendue (par exemple, des problèmes de saisie utilisateur) ou inattendue (par exemple, des bugs).
- erreurs?: une liste facultative pour inclure des détails plus spécifiques sur l'erreur (utile pour les erreurs de validation).
Un middleware simple de gestion des erreurs
Maintenant que nous avons notre classe d'erreur personnalisée, nous avons besoin d'un moyen de gérer ces erreurs dans notre application. Entrez le middleware?:
export const errorHandler = (err, req, res, next) => { if (err instanceof AppError) { // Handle operational errors res.status(err.httpCode).json({ success: false, error: err.name, message: err.message, errors: err.errors || [], }); } else { // Handle unexpected errors console.error('Unexpected Error:', err.stack); // Log the stack trace for debugging res.status(500).json({ success: false, error: 'InternalServerError', message: 'Something went wrong. Please try again later.', }); } };
Qu'est-ce que ?a fait ?
Vérifie le type d'erreur?:
Si l’erreur est une instance d’AppError, elle est traitée comme une erreur opérationnelle. Ce sont les erreurs que vous anticipez (par exemple, des problèmes de validation ou des ressources manquantes).
S’il ne s’agit pas d’une AppError, elle est traitée comme une erreur inattendue. Il peut s'agir de bugs dans votre code ou de quelque chose que vous n'aviez pas prévu.
Responds with the right status code and message: For AppError instances, it sends a structured JSON response containing the error details. For unexpected errors, it sends a generic 500 response to the user and logs the details for debugging.
Rassembler tout ?a
Imaginez que vous ayez un itinéraire dans votre application Express dans lequel les utilisateurs soumettent un formulaire, mais que certains champs manquent. Vous pouvez utiliser votre classe AppError comme ceci?:
app.post('/submit-form', (req, res, next) => { const { name, email } = req.body; if (!name || !email) { const errors = []; if (!name) errors.push({ field: 'name', message: 'Name is required.' }); if (!email) errors.push({ field: 'email', message: 'Email is required.' }); return next(new AppError('ValidationError', 400, 'Invalid input data.', true, errors)); } res.json({ success: true, message: 'Form submitted successfully!' }); }); // Register the error-handling middleware app.use(errorHandler);
Que se passe-t-il en cas d'erreur??
Si le nom ou l'e-mail est manquant, l'instance AppError est transmise à la fonction suivante.
Le middleware errorHandler l'attrape et envoie une réponse JSON structurée?:
{ "success": false, "error": "ValidationError", "message": "Invalid input data.", "errors": [ { "field": "name", "message": "Name is required." }, { "field": "email", "message": "Email is required." } ] }
Pourquoi utiliser ce modèle??
- Clarté?: les classes d'erreurs personnalisées rendent vos erreurs plus descriptives et plus faciles à déboguer.
- Cohérence?: chaque erreur suit une structure prévisible, ce qui la rend plus facile à gérer pour les développeurs frontend.
- Séparation des préoccupations?: vos gestionnaires de routes se concentrent sur la logique, tandis que le middleware gère la réponse aux erreurs.
Conclusion
La gestion des erreurs ne doit pas nécessairement être complexe?! En utilisant une classe d'erreurs et un middleware personnalisés, vous pouvez créer un système robuste et convivial pour les débutants qui garantit la fiabilité de votre application et la satisfaction de vos utilisateurs.
Que pensez-vous de cette approche ? Avez-vous des conseils ou astuces pour gérer les erreurs dans Node.js ? Faites-le moi savoir dans les commentaires ci-dessous !
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Java et JavaScript sont différents langages de programmation, chacun adapté à différents scénarios d'application. Java est utilisé pour le développement des grandes entreprises et des applications mobiles, tandis que JavaScript est principalement utilisé pour le développement de pages Web.

JavaScriptCommentsaSententialFormantaining, Reading et GuidingCodeEexecution.1) unique-linecomesaUSEUSEFORQUICKEXPLANATIONS.2) Multi-linecommentSExPlainComplexLogicorProvideTailedDocumentation.3) Inlinecomementsclarifypecifications

Les points suivants doivent être notés lors du traitement des dates et du temps dans JavaScript: 1. Il existe de nombreuses fa?ons de créer des objets de date. Il est recommandé d'utiliser les cha?nes de format ISO pour assurer la compatibilité; 2. Get and définir des informations de temps peuvent être obtenues et définir des méthodes, et notez que le mois commence à partir de 0; 3. Les dates de mise en forme manuelle nécessitent des cha?nes et les bibliothèques tierces peuvent également être utilisées; 4. Il est recommandé d'utiliser des bibliothèques qui prennent en charge les fuseaux horaires, comme Luxon. La ma?trise de ces points clés peut éviter efficacement les erreurs courantes.

PlacertagsatthebottomofablogPostorwebPageSerSpracticalPurpossForseo, userexperience, anddesign.1.ithelpswithseobyallowingsechingenginestoaccesskeyword-elevanttagswithoutcluteringtheaincontent..itimproveserexperceenceegmentyepingthefocusonThearrlUl

Javascriptispreferredforwebdevelopment, tandis que javaisbetterforlarge-scalebackenSystemsandandroidApps.1)

JavascripthSsevenfundamentalDatatypes: nombre, cha?ne, booléen, indéfini, nul, objet, andymbol.1) nombres usUseadouble-précisformat, utile

La capture d'événements et la bulle sont deux étapes de la propagation des événements dans DOM. La capture est de la couche supérieure à l'élément cible, et la bulle est de l'élément cible à la couche supérieure. 1. La capture de l'événement est implémentée en définissant le paramètre UseCapture d'AdveventListener sur true; 2. événement Bubble est le comportement par défaut, UseCapture est défini sur False ou Omise; 3. La propagation des événements peut être utilisée pour empêcher la propagation des événements; 4. événement Bubbling prend en charge la délégation d'événements pour améliorer l'efficacité du traitement du contenu dynamique; 5. La capture peut être utilisée pour intercepter les événements à l'avance, telles que la journalisation ou le traitement des erreurs. La compréhension de ces deux phases aide à contr?ler avec précision le calendrier et comment JavaScript répond aux opérations utilisateur.

Java et JavaScript sont différents langages de programmation. 1.Java est un langage typique et compilé, adapté aux applications d'entreprise et aux grands systèmes. 2. JavaScript est un type dynamique et un langage interprété, principalement utilisé pour l'interaction Web et le développement frontal.
