Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lernen Implementierung der "GET POST BY ID"-Route | Entwicklung von REST-API
Backend-Entwicklung mit Node.js und Express.js

book
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 Ordner database befindet.

Routendefinition

Der folgende Code definiert die Route "GET POST BY ID" mit router.get():

js
router.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:

js
const 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:

js
const 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 oder undefined , wenn kein Treffer gefunden wird.

Umgang mit der Antwort

Wir behandeln die Antwort basierend darauf, ob ein Beitrag gefunden wurde oder nicht:

js
if (!post) {
res.status(404).json({ error: "Post not found" });
} else {
res.status(200).send(post);
}
  • Wenn kein Beitrag gefunden wurde (d.h. post ist undefined ), 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:

js
try {
// ... (code for retrieving and processing data)
} catch (error) {
console.error(error.message);
}

Vollständiger Code der Datei postsRoutes.js in diesem Schritt

js
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

War alles klar?

Wie können wir es verbessern?

Danke für Ihr Feedback!

Abschnitt 4. Kapitel 6

Fragen Sie AI

expand
ChatGPT

Fragen Sie alles oder probieren Sie eine der vorgeschlagenen Fragen, um unser Gespräch zu beginnen

We use cookies to make your experience better!
some-alt