Implementierung der "GET POST BY ID"-Route
Wir werden die Implementierung der Route "GET POST BY ID" innerhalb der Datei postsRoutes.js file
untersuchen. Diese Route ruft einen bestimmten Beitrag ab und gibt ihn zurück, basierend auf seinem eindeutigen Bezeichner (id
), der als Teil der URL bereitgestellt wird.
Hinweis
Der Begriff 'Datenbank' bezieht sich speziell auf die Datei
posts.json
, die sich im Ordnerdatabase
befindet.
Routendefinition
Der folgende Code definiert die Route "GET POST BY ID" mit router.get()
:
jsrouter.get("/post/:id", async (req, res, next) => { ... }
Diese Route ist konfiguriert, um HTTP-GET-Anfragen zu bearbeiten;
Der Routenpfad
/post/:id
enthält einen Parameter:id
, der die Post-ID aus der URL erfasst.
Extrahieren der Post-ID
Wir extrahieren die Post-ID aus den Anforderungsparametern mit req.params.id
:
jsconst postId = req.params.id;
Diese Zeile erfasst den :id
-Wert aus der URL und macht ihn für die weitere Verarbeitung verfügbar.
Finden des Posts in der Datenbank
Als nächstes suchen wir nach dem Post mit der passenden ID in der Datenbank:
js9123const data = await readData();const post = data.find((post) => post.id === postId);
Wir verwenden die asynchrone Funktion
readData
, um Daten aus der JSON-Datei abzurufen;Die Methode
find()
wird verwendet, um einen Post mit einer passenden ID innerhalb der abgerufenen Daten zu finden;Die Variable
post
enthält den gefundenen Post oderundefined
, wenn kein Treffer gefunden wird.
Umgang mit der Antwort
Wir behandeln die Antwort basierend darauf, ob ein Beitrag gefunden wurde oder nicht:
js912345if (!post) {res.status(404).json({ error: "Post not found" });} else {res.status(200).send(post);}
Wenn kein Beitrag gefunden wurde (d.h.
post
istundefined
), senden wir eine 404-Antwort zusammen mit einer Fehlermeldung, die darauf hinweist, dass der angeforderte Beitrag nicht gefunden wurde;Wenn ein Beitrag gefunden wurde, senden wir den Beitrag als Antwort mit einem Statuscode von 200 (OK).
Fehlerbehandlung
Wir umschließen den Routencode in einem Try-Catch-Block, um potenzielle Fehler während der Datenabfrage oder der Anforderungsverarbeitung zu behandeln. Alle auftretenden Fehler werden zur Debugging-Zwecken in der Konsole protokolliert:
js912345try {// ... (code for retrieving and processing data)} catch (error) {console.error(error.message);}
Vollständiger Code der Datei postsRoutes.js in diesem Schritt
js99123456789101112131415161718192021222324252627282930313233343536const express = require("express");const fs = require("fs/promises");const validatePostData = require("../middlewares/validateData");const router = express.Router();// Function to read data from the JSON fileasync function readData() {try {// Read the contents of the `posts.json` fileconst data = await fs.readFile("./database/posts.json");// Parse the JSON data into a JavaScript objectreturn JSON.parse(data);} catch (error) {// If an error occurs during reading or parsing, throw the errorthrow error;}}// GET ALL POSTSrouter.get("/", async (req, res, next) => {try {// Call the `readData` function to retrieve the list of postsconst data = await readData();// Send the retrieved data as the responseres.status(200).send(data);} catch (error) {// If an error occurs during data retrieval or sending the responseconsole.error(error.message); // Log the error to the console for debugging}});// GET POST BY IDrouter.get("/post/:id", async (req, res, next) => {try {// Extract the post ID from the request parameters
Danke für Ihr Feedback!
Fragen Sie AI
Fragen Sie alles oder probieren Sie eine der vorgeschlagenen Fragen, um unser Gespräch zu beginnen