Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Apprendre Implémentation de la Route "CREATE POST" | Développement d'API REST
Développement Backend Avec Node.js et Express.js
course content

Contenu du cours

Développement Backend Avec Node.js et Express.js

Développement Backend Avec Node.js et Express.js

1. Introduction
2. Applications Console
3. Cadre Express.js
4. Développement d'API REST

book
Implémentation de la Route "CREATE POST"

Nous allons examiner la création d'un nouveau post en utilisant la route "CREATE POST" dans le fichier postsRoutes.js. Cette route est responsable de la gestion de la création d'un post et de son enregistrement dans la source de données (database/posts.json).

Définition de la Route

Le code ci-dessous définit la route "CREATE POST" en utilisant router.post():

  • Cette route est configurée pour gérer les requêtes HTTP POST vers le chemin racine /;
  • Elle utilise le middleware validatePostData, qui garantit que les données envoyées dans le corps de la requête sont valides avant de continuer.

Middleware de Validation des Données

Avant de plonger dans la logique de la route, nous devons créer un middleware de validation des données. Ce middleware garantit que les données envoyées dans le corps de la requête sont valides avant de tenter de créer un nouveau post.

  • La fonction validatePostData extrait username, postTitle, et postContent du corps de la requête;
  • Elle vérifie si ces champs sont présents. Si l'un d'eux manque (!username, !postTitle, ou !postContent), elle répond avec un code de statut 400 (Bad Request) et un message d'erreur indiquant les champs requis manquants;
  • Si les données sont valides, le middleware appelle next(), permettant à la requête de continuer vers le gestionnaire de route (la route "CREATE POST" dans ce cas).

Avec le middleware de validation des données en place, continuons avec la logique de la route "CREATE POST".

Données du Nouveau Post

Pour créer un nouveau post, nous générons un ID unique en utilisant Date.now().toString(). De plus, nous extrayons username, postTitle, et postContent du corps de la requête.

Ajouter le Nouveau Post à la Base de Données

Les étapes suivantes détaillent comment le nouveau post est ajouté à la base de données :

  • Les données existantes sont lues à partir du fichier JSON en utilisant la fonction asynchrone readData, comme expliqué précédemment;
  • Le nouveau post est ajouté au tableau data;
  • Le tableau data mis à jour est ensuite réécrit dans le fichier JSON pour enregistrer le post nouvellement créé.

Envoi d'une Réponse

Après la création réussie du nouveau post, une réponse de succès est envoyée au client. La réponse inclut un code de statut de 201 (Créé) et les détails du post nouvellement créé au format JSON.

Gestion des Erreurs

Nous enveloppons le code de la route dans un bloc try-catch pour gérer les erreurs potentielles lors de la récupération des données ou du traitement de la requête. Toute erreur survenant est enregistrée dans la console à des fins de débogage :

Code complet du fichier postsRoutes.js à cette étape

Code complet du fichier validateData.js

Tout était clair ?

Comment pouvons-nous l'améliorer ?

Merci pour vos commentaires !

Section 4. Chapitre 7
We're sorry to hear that something went wrong. What happened?
some-alt