Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lernen Implementierung der "Create Post"-Route | 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 "Create Post"-Route

Wir werden die Erstellung eines neuen Beitrags mit der Route "CREATE POST" innerhalb der Datei postsRoutes.js untersuchen. Diese Route ist dafür verantwortlich, die Erstellung eines Beitrags zu bearbeiten und ihn in der Datenquelle (database/posts.json) zu speichern.

Routendefinition

Der folgende Code definiert die Route "CREATE POST" mit router.post():

  • Diese Route ist so konfiguriert, dass sie HTTP-POST-Anfragen an den Stammweg / verarbeitet;
  • Sie nutzt die Middleware validatePostData, die sicherstellt, dass die im Anforderungskörper gesendeten Daten gültig sind, bevor fortgefahren wird.

Datenvalidierungs-Middleware

Bevor wir uns mit der Logik der Route befassen, müssen wir eine Datenvalidierungs-Middleware erstellen. Diese Middleware stellt sicher, dass die im Anforderungstext gesendeten Daten gültig sind, bevor versucht wird, einen neuen Beitrag zu erstellen.

  • Die Funktion validatePostData extrahiert username, postTitle und postContent aus dem Anforderungstext;
  • Sie überprüft, ob diese Felder vorhanden sind. Wenn eines von ihnen fehlt (!username, !postTitle oder !postContent), antwortet sie mit einem 400 (Bad Request) Statuscode und einer Fehlermeldung, die auf fehlende erforderliche Felder hinweist;
  • Wenn die Daten gültig sind, ruft die Middleware next() auf, wodurch die Anforderung zum Routen-Handler (in diesem Fall die "CREATE POST"-Route) fortgesetzt wird.

Mit der Datenvalidierungs-Middleware an Ort und Stelle, lassen Sie uns mit der Logik der "CREATE POST"-Route fortfahren.

Neue Beitragsdaten

Um einen neuen Beitrag zu erstellen, generieren wir eine eindeutige ID mit Date.now().toString(). Zusätzlich extrahieren wir username, postTitle und postContent aus dem Anforderungstext.

Den neuen Beitrag zur Datenbank hinzufügen

Die folgenden Schritte beschreiben, wie der neue Beitrag zur Datenbank hinzugefügt wird:

  • Die vorhandenen Daten werden mit der asynchronen Funktion readData aus der JSON-Datei gelesen, wie zuvor erklärt;
  • Der neue Beitrag wird dem data-Array hinzugefügt;
  • Das aktualisierte data-Array wird dann zurück in die JSON-Datei geschrieben, um den neu erstellten Beitrag zu speichern.

Senden einer Antwort

Nach erfolgreicher Erstellung des neuen Beitrags wird eine Erfolgsantwort an den Client gesendet. Die Antwort enthält einen Statuscode von 201 (Created) und die Details des neu erstellten Beitrags im JSON-Format.

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

Vollständiger Code der Datei validateData.js

War alles klar?

Wie können wir es verbessern?

Danke für Ihr Feedback!

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