Création du Point de Terminaison Update Post par Identifiant
Nous allons examiner comment mettre à jour un post existant en utilisant la route « UPDATE POST BY ID » dans le fichier postsRoutes.js. Cette route gère la mise à jour d’un post en fonction de son identifiant unique.
Définition de la route
Le code ci-dessous définit la route « UPDATE POST BY ID » à l’aide de router.put() :
router.put("/post/:id", validatePostData, async (req, res, next) => { ... }
- Cette route est configurée pour traiter les requêtes HTTP PUT, spécifiquement pour la mise à jour des posts ;
- Elle inclut un paramètre
:iddans le chemin de la route pour identifier le post à mettre à jour ; - Le middleware
validatePostDataest ajouté afin d’assurer la validation des données avant de poursuivre. La logique du middlewarevalidatePostDatareste identique à celle de l’étape précédente.
Obtention des données depuis la requête
Ici, nous extrayons les données nécessaires de la requête, y compris l'identifiant du post et le contenu mis à jour du post :
const postId = req.params.id;
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
- L'identifiant du post est extrait des paramètres de la requête, ce qui le rend disponible pour un traitement ultérieur. Le paramètre
:idde l'URL de la route est capturé à l'aide dereq.params.id; - Les champs
username,postTitleetpostContentsont extraits du corps de la requête.
Mise à jour du post dans la base de données
La mise à jour d'un post existant implique plusieurs étapes, décrites ci-dessous :
const data = await readData();
const postIndex = data.findIndex((post) => post.id === postId);
if (postIndex === -1) {
return res.status(404).json({ error: "Post not found" });
}
data[postIndex] = {
...data[postIndex],
...updatedData,
};
await fs.writeFile("./database/posts.json", JSON.stringify(data));
- Les données existantes sont lues depuis le fichier JSON à l'aide de la fonction asynchrone
readData, comme expliqué précédemment ; - La variable
postIndexstocke l'index du post à mettre à jour dans le tableaudataen comparant les identifiants des posts ; - Si le post n'est pas trouvé (c'est-à-dire
postIndex === -1), une réponse 404 (Non trouvé) avec un message d'erreur est renvoyée au client ; - Pour mettre à jour les données du post, nous fusionnons les données existantes du post (
...data[postIndex]) avec les données mises à jour (...updatedData). Cela garantit que seuls les champs spécifiés sont mis à jour et que les données existantes sont conservées ; - Enfin, le tableau
datamis à jour est réécrit dans le fichier JSON afin d'enregistrer les modifications apportées au post.
Envoi d'une réponse
Après la mise à jour réussie du post, une réponse JSON est envoyée au client. La réponse inclut un code de statut 200 (OK), indiquant une mise à jour réussie ainsi que les données du post mises à jour.
res.status(200).json(data[postIndex]);
Gestion des erreurs
Le code de la route est encapsulé dans un bloc try-catch afin de 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 :
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
Code complet du fichier postsRoutes.js à cette étape
const express = require("express");
const fs = require("fs/promises");
const validatePostData = require("../middlewares/validateData");
const router = express.Router();
// Function to read data from the JSON file
async function readData() {
try {
// Read the contents of the `posts.json` file
const data = await fs.readFile("./database/posts.json");
// Parse the JSON data into a JavaScript object
return JSON.parse(data);
} catch (error) {
// If an error occurs during reading or parsing, throw the error
throw error;
}
}
// GET ALL POSTS
router.get("/", async (req, res, next) => {
try {
// Call the `readData` function to retrieve the list of posts
const data = await readData();
// Send the retrieved data as the response
res.status(200).send(data);
} catch (error) {
// If an error occurs during data retrieval or sending the response
console.error(error.message); // Log the error to the console for debugging
}
});
// GET POST BY ID
router.get("/post/:id", async (req, res, next) => {
try {
// Extract the post ID from the request parameters
const postId = req.params.id;
// Read data from the JSON file
const data = await readData();
// Find the post with the matching ID
const post = data.find((post) => post.id === postId);
// If the post is not found, send a 404 response
if (!post) {
res.status(404).json({ error: "Post not found" });
} else {
// If the post is found, send it as the response
res.status(200).send(post);
}
} catch (error) {
// Handle errors by logging them and sending an error response
console.error(error.message);
}
});
// CREATE POST
router.post("/", validatePostData, async (req, res, next) => {
try {
const newPost = {
id: Date.now().toString(), // Generate a unique ID for the new post
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
// Read the existing data
const data = await readData();
// Add the new post to the data
data.push(newPost);
// Write the updated data back to the JSON file
await fs.writeFile("./database/posts.json", JSON.stringify(data));
// Send a success response with the new post
res.status(201).json(newPost);
} catch (error) {
// Handle errors by logging them to the console
console.error(error.message);
}
});
// UPDATE POST BY ID
router.put("/post/:id", validatePostData, async (req, res, next) => {
try {
// Extract the post ID from the request parameters
const postId = req.params.id;
// Extract the updated data from the request body
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
// Read the existing data
const data = await readData();
// Find the index of the post with the specified ID in the data array
const postIndex = data.findIndex((post) => post.id === postId);
// If the post with the specified ID doesn't exist, return a 404 error
if (postIndex === -1) {
return res.status(404).json({ error: "Post not found" });
}
// Update the post data with the new data using spread syntax
data[postIndex] = {
...data[postIndex], // Keep existing data
...updatedData, // Apply updated data
};
// Write the updated data back
await fs.writeFile("./database/posts.json", JSON.stringify(data));
// Send a success response with the updated post
res.status(200).json(data[postIndex]);
} catch (error) {
console.error(error.message);
next(error);
}
});
Merci pour vos commentaires !
Demandez à l'IA
Demandez à l'IA
Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion
Can you explain how the validatePostData middleware works?
What should I do if I get a "Post not found" error when updating?
Can you show how to test the update route with an example request?
Awesome!
Completion rate improved to 2.56
Création du Point de Terminaison Update Post par Identifiant
Glissez pour afficher le menu
Nous allons examiner comment mettre à jour un post existant en utilisant la route « UPDATE POST BY ID » dans le fichier postsRoutes.js. Cette route gère la mise à jour d’un post en fonction de son identifiant unique.
Définition de la route
Le code ci-dessous définit la route « UPDATE POST BY ID » à l’aide de router.put() :
router.put("/post/:id", validatePostData, async (req, res, next) => { ... }
- Cette route est configurée pour traiter les requêtes HTTP PUT, spécifiquement pour la mise à jour des posts ;
- Elle inclut un paramètre
:iddans le chemin de la route pour identifier le post à mettre à jour ; - Le middleware
validatePostDataest ajouté afin d’assurer la validation des données avant de poursuivre. La logique du middlewarevalidatePostDatareste identique à celle de l’étape précédente.
Obtention des données depuis la requête
Ici, nous extrayons les données nécessaires de la requête, y compris l'identifiant du post et le contenu mis à jour du post :
const postId = req.params.id;
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
- L'identifiant du post est extrait des paramètres de la requête, ce qui le rend disponible pour un traitement ultérieur. Le paramètre
:idde l'URL de la route est capturé à l'aide dereq.params.id; - Les champs
username,postTitleetpostContentsont extraits du corps de la requête.
Mise à jour du post dans la base de données
La mise à jour d'un post existant implique plusieurs étapes, décrites ci-dessous :
const data = await readData();
const postIndex = data.findIndex((post) => post.id === postId);
if (postIndex === -1) {
return res.status(404).json({ error: "Post not found" });
}
data[postIndex] = {
...data[postIndex],
...updatedData,
};
await fs.writeFile("./database/posts.json", JSON.stringify(data));
- Les données existantes sont lues depuis le fichier JSON à l'aide de la fonction asynchrone
readData, comme expliqué précédemment ; - La variable
postIndexstocke l'index du post à mettre à jour dans le tableaudataen comparant les identifiants des posts ; - Si le post n'est pas trouvé (c'est-à-dire
postIndex === -1), une réponse 404 (Non trouvé) avec un message d'erreur est renvoyée au client ; - Pour mettre à jour les données du post, nous fusionnons les données existantes du post (
...data[postIndex]) avec les données mises à jour (...updatedData). Cela garantit que seuls les champs spécifiés sont mis à jour et que les données existantes sont conservées ; - Enfin, le tableau
datamis à jour est réécrit dans le fichier JSON afin d'enregistrer les modifications apportées au post.
Envoi d'une réponse
Après la mise à jour réussie du post, une réponse JSON est envoyée au client. La réponse inclut un code de statut 200 (OK), indiquant une mise à jour réussie ainsi que les données du post mises à jour.
res.status(200).json(data[postIndex]);
Gestion des erreurs
Le code de la route est encapsulé dans un bloc try-catch afin de 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 :
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
Code complet du fichier postsRoutes.js à cette étape
const express = require("express");
const fs = require("fs/promises");
const validatePostData = require("../middlewares/validateData");
const router = express.Router();
// Function to read data from the JSON file
async function readData() {
try {
// Read the contents of the `posts.json` file
const data = await fs.readFile("./database/posts.json");
// Parse the JSON data into a JavaScript object
return JSON.parse(data);
} catch (error) {
// If an error occurs during reading or parsing, throw the error
throw error;
}
}
// GET ALL POSTS
router.get("/", async (req, res, next) => {
try {
// Call the `readData` function to retrieve the list of posts
const data = await readData();
// Send the retrieved data as the response
res.status(200).send(data);
} catch (error) {
// If an error occurs during data retrieval or sending the response
console.error(error.message); // Log the error to the console for debugging
}
});
// GET POST BY ID
router.get("/post/:id", async (req, res, next) => {
try {
// Extract the post ID from the request parameters
const postId = req.params.id;
// Read data from the JSON file
const data = await readData();
// Find the post with the matching ID
const post = data.find((post) => post.id === postId);
// If the post is not found, send a 404 response
if (!post) {
res.status(404).json({ error: "Post not found" });
} else {
// If the post is found, send it as the response
res.status(200).send(post);
}
} catch (error) {
// Handle errors by logging them and sending an error response
console.error(error.message);
}
});
// CREATE POST
router.post("/", validatePostData, async (req, res, next) => {
try {
const newPost = {
id: Date.now().toString(), // Generate a unique ID for the new post
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
// Read the existing data
const data = await readData();
// Add the new post to the data
data.push(newPost);
// Write the updated data back to the JSON file
await fs.writeFile("./database/posts.json", JSON.stringify(data));
// Send a success response with the new post
res.status(201).json(newPost);
} catch (error) {
// Handle errors by logging them to the console
console.error(error.message);
}
});
// UPDATE POST BY ID
router.put("/post/:id", validatePostData, async (req, res, next) => {
try {
// Extract the post ID from the request parameters
const postId = req.params.id;
// Extract the updated data from the request body
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
// Read the existing data
const data = await readData();
// Find the index of the post with the specified ID in the data array
const postIndex = data.findIndex((post) => post.id === postId);
// If the post with the specified ID doesn't exist, return a 404 error
if (postIndex === -1) {
return res.status(404).json({ error: "Post not found" });
}
// Update the post data with the new data using spread syntax
data[postIndex] = {
...data[postIndex], // Keep existing data
...updatedData, // Apply updated data
};
// Write the updated data back
await fs.writeFile("./database/posts.json", JSON.stringify(data));
// Send a success response with the updated post
res.status(200).json(data[postIndex]);
} catch (error) {
console.error(error.message);
next(error);
}
});
Merci pour vos commentaires !