Opbygning af Update-Post Efter Id-Endepunkt
Vi undersøger, hvordan man opdaterer et eksisterende opslag ved hjælp af "UPDATE POST BY ID"-ruten i filen postsRoutes.js. Denne rute håndterer opdatering af et opslag baseret på dets unikke ID.
Rutedefinition
Koden nedenfor definerer "UPDATE POST BY ID"-ruten ved brug af router.put():
router.put("/post/:id", validatePostData, async (req, res, next) => { ... }
- Denne rute er konfigureret til at håndtere HTTP PUT-anmodninger, specifikt til opdatering af opslag;
- Den indeholder en parameteriseret
:idi rutestien for at identificere det opslag, der skal opdateres; - Middleware-funktionen
validatePostDataer tilføjet for at sikre datavalidering, før der fortsættes. Logikken ivalidatePostData-middleware forbliver den samme som i det forrige trin.
Indhentning af data fra anmodningen
Her udtrækkes de nødvendige data fra anmodningen, herunder post-ID og det opdaterede postindhold:
const postId = req.params.id;
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
- Post-ID'et udtrækkes fra anmodningsparametrene, hvilket gør det tilgængeligt til videre behandling.
:id-parameteren fra rute-URL'en opfanges ved hjælp afreq.params.id; username,postTitleogpostContentudtrækkes fra anmodningskroppen.
Opdatering af posten i databasen
Opdatering af et eksisterende opslag indebærer flere trin, som beskrevet nedenfor:
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));
- De eksisterende data læses fra JSON-filen ved hjælp af den asynkrone funktion
readData, som tidligere beskrevet; - Variablen
postIndexgemmer indekset for det opslag, der skal opdateres idata-arrayet ved at sammenligne post-ID'er; - Hvis opslaget ikke findes (dvs.
postIndex === -1), returneres et 404 (Ikke fundet)-svar med en fejlmeddelelse til klienten; - For at opdatere postdataene flettes de eksisterende postdata (
...data[postIndex]) med de opdaterede data (...updatedData). Dette sikrer, at kun de angivne felter opdateres, og eksisterende data bevares; - Til sidst skrives det opdaterede
data-array tilbage til JSON-filen for at gemme de foretagne ændringer af opslaget.
Afsendelse af svar
Når opslaget er opdateret korrekt, sendes et JSON-svar til klienten. Svaret indeholder statuskoden 200 (OK), hvilket angiver en vellykket opdatering samt de opdaterede postdata.
res.status(200).json(data[postIndex]);
Fejlhåndtering
Rutekoden indpakkes i et try-catch-blok for at håndtere potentielle fejl under datahentning eller anmodningsbehandling. Eventuelle fejl, der opstår, logges til konsollen til fejlfinding:
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
Komplet kode for postsRoutes.js-filen på dette trin
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);
}
});
Tak for dine kommentarer!
Spørg AI
Spørg AI
Spørg om hvad som helst eller prøv et af de foreslåede spørgsmål for at starte vores chat
Awesome!
Completion rate improved to 2.56
Opbygning af Update-Post Efter Id-Endepunkt
Stryg for at vise menuen
Vi undersøger, hvordan man opdaterer et eksisterende opslag ved hjælp af "UPDATE POST BY ID"-ruten i filen postsRoutes.js. Denne rute håndterer opdatering af et opslag baseret på dets unikke ID.
Rutedefinition
Koden nedenfor definerer "UPDATE POST BY ID"-ruten ved brug af router.put():
router.put("/post/:id", validatePostData, async (req, res, next) => { ... }
- Denne rute er konfigureret til at håndtere HTTP PUT-anmodninger, specifikt til opdatering af opslag;
- Den indeholder en parameteriseret
:idi rutestien for at identificere det opslag, der skal opdateres; - Middleware-funktionen
validatePostDataer tilføjet for at sikre datavalidering, før der fortsættes. Logikken ivalidatePostData-middleware forbliver den samme som i det forrige trin.
Indhentning af data fra anmodningen
Her udtrækkes de nødvendige data fra anmodningen, herunder post-ID og det opdaterede postindhold:
const postId = req.params.id;
const updatedData = {
username: req.body.username,
postTitle: req.body.postTitle,
postContent: req.body.postContent,
};
- Post-ID'et udtrækkes fra anmodningsparametrene, hvilket gør det tilgængeligt til videre behandling.
:id-parameteren fra rute-URL'en opfanges ved hjælp afreq.params.id; username,postTitleogpostContentudtrækkes fra anmodningskroppen.
Opdatering af posten i databasen
Opdatering af et eksisterende opslag indebærer flere trin, som beskrevet nedenfor:
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));
- De eksisterende data læses fra JSON-filen ved hjælp af den asynkrone funktion
readData, som tidligere beskrevet; - Variablen
postIndexgemmer indekset for det opslag, der skal opdateres idata-arrayet ved at sammenligne post-ID'er; - Hvis opslaget ikke findes (dvs.
postIndex === -1), returneres et 404 (Ikke fundet)-svar med en fejlmeddelelse til klienten; - For at opdatere postdataene flettes de eksisterende postdata (
...data[postIndex]) med de opdaterede data (...updatedData). Dette sikrer, at kun de angivne felter opdateres, og eksisterende data bevares; - Til sidst skrives det opdaterede
data-array tilbage til JSON-filen for at gemme de foretagne ændringer af opslaget.
Afsendelse af svar
Når opslaget er opdateret korrekt, sendes et JSON-svar til klienten. Svaret indeholder statuskoden 200 (OK), hvilket angiver en vellykket opdatering samt de opdaterede postdata.
res.status(200).json(data[postIndex]);
Fejlhåndtering
Rutekoden indpakkes i et try-catch-blok for at håndtere potentielle fejl under datahentning eller anmodningsbehandling. Eventuelle fejl, der opstår, logges til konsollen til fejlfinding:
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}
Komplet kode for postsRoutes.js-filen på dette trin
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);
}
});
Tak for dine kommentarer!