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

Kursinhalt

Backend-Entwicklung mit Node.js und Express.js

Backend-Entwicklung mit Node.js und Express.js

1. Einführung
2. Konsolenanwendungen
3. Express.js Framework
4. Entwicklung von REST-API

book
Implementierung der Route "Post Nach ID Aktualisieren"

Wir werden untersuchen, wie man einen bestehenden Beitrag mit der Route "UPDATE POST BY ID" innerhalb der Datei postsRoutes.js aktualisiert. Diese Route behandelt die Aktualisierung eines Beitrags basierend auf seiner eindeutigen ID.

Routendefinition

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

  • Diese Route ist konfiguriert, um HTTP PUT-Anfragen zu bearbeiten, speziell für die Aktualisierung von Beiträgen;
  • Sie enthält einen parametrisierten :id im Routenpfad, um den zu aktualisierenden Beitrag zu identifizieren;
  • Das validatePostData Middleware wird hinzugefügt, um die Datenvalidierung vor dem Fortfahren sicherzustellen. Die Logik des validatePostData Middleware bleibt gleich wie im vorherigen Schritt.

Daten aus der Anfrage erhalten

Hier extrahieren wir die notwendigen Daten aus der Anfrage, einschließlich der Post-ID und des aktualisierten Post-Inhalts:

  • Die Post-ID wird aus den Anfrageparametern extrahiert und steht für die weitere Verarbeitung zur Verfügung. Der :id-Parameter aus der Routen-URL wird mit req.params.id erfasst;
  • Der username, postTitle und postContent werden aus dem Anfragekörper extrahiert.

Aktualisieren des Posts in der Datenbank

Das Aktualisieren eines bestehenden Posts umfasst mehrere Schritte, wie unten beschrieben:

  • Wir lesen die vorhandenen Daten aus der JSON-Datei mit der asynchronen readData-Funktion, wie zuvor erklärt;
  • Die Variable postIndex speichert den Index des zu aktualisierenden Posts im data-Array, indem Post-IDs verglichen werden;
  • Wenn der Post nicht gefunden wird (d.h. postIndex === -1), wird eine 404 (Nicht gefunden) Antwort mit einer Fehlermeldung an den Client zurückgegeben;
  • Um die Post-Daten zu aktualisieren, kombinieren wir die vorhandenen Post-Daten (...data[postIndex]) mit den aktualisierten Daten (...updatedData). Dies stellt sicher, dass nur die angegebenen Felder aktualisiert werden und vorhandene Daten erhalten bleiben;
  • Schließlich wird das aktualisierte data-Array zurück in die JSON-Datei geschrieben, um die vorgenommenen Änderungen am Post zu speichern.

Senden einer Antwort

Nach erfolgreicher Aktualisierung des Posts wird eine JSON-Antwort an den Client gesendet. Die Antwort enthält einen Statuscode von 200 (OK), der eine erfolgreiche Aktualisierung und die aktualisierten Post-Daten anzeigt.

Fehlerbehandlung

Wir umschließen den Routencode in einem Try-Catch-Block, um potenzielle Fehler bei der Datenabfrage oder der Anforderungsverarbeitung zu behandeln. Alle auftretenden Fehler werden zur Debugging-Zwecken in der Konsole protokolliert:

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

War alles klar?

Wie können wir es verbessern?

Danke für Ihr Feedback!

Abschnitt 4. Kapitel 8
We're sorry to hear that something went wrong. What happened?
some-alt