Kursinhalt
Backend-Entwicklung mit Node.js und Express.js
Backend-Entwicklung mit Node.js und Express.js
Implementierung der "Delete Post by ID"-Route
Wir werden in die Implementierung der Route "DELETE POST BY ID" innerhalb der Datei postsRoutes.js
eintauchen. Diese Route ermöglicht es den Clients, einen bestimmten Beitrag zu löschen, indem sie seine eindeutige ID angeben.
Routendefinition
Der folgende Code definiert die Route "DELETE POST BY ID" mit router.delete()
:
Diese Route verarbeitet HTTP DELETE-Anfragen mit einem parametrisierten :id
im Routenpfad. Der :id
-Parameter wird verwendet, um den zu löschenden Beitrag zu identifizieren. Wir benötigen kein zusätzliches Middleware wie dataValidation
, da wir alle notwendigen Informationen aus dem URL-Parameter erhalten.
Extrahieren der Post-ID
Wir extrahieren die Post-ID aus den Anforderungsparametern mit req.params.id
:
Diese Zeile erfasst den :id
-Wert aus der URL, sodass wir im nachfolgenden Code damit arbeiten können.
Löschen des Beitrags
So löschen wir den Beitrag:
- Wir beginnen damit, die vorhandenen Daten aus der JSON-Datei mit der asynchronen Funktion
readData
zu lesen, wie zuvor erklärt. - Wir finden den Index des zu löschenden Beitrags im
data
-Array, indem wir die Post-IDs vergleichen. - Wenn der Beitrag nicht gefunden wird (d.h.
postIndex === -1
), geben wir eine 404 (Nicht gefunden) Antwort mit einer Fehlermeldung zurück. - Mit der
splice
-Methode entfernen wir die Beitragsdaten aus demdata
-Array. Die VariablepostIndex
bestimmt die Position des zu löschenden Beitrags. - Das aktualisierte
data
-Array, aus dem der Beitrag entfernt wurde, wird dann zurück in die JSON-Datei geschrieben, um die während der Löschung vorgenommenen Änderungen zu speichern.
Senden einer Antwort
Eine JSON-Antwort mit einem Statuscode von 200 (OK) wird an den Client gesendet, um eine erfolgreiche Löschung anzuzeigen. Die Antwort enthält eine Nachricht, die bestätigt, dass der Beitrag erfolgreich gelöscht wurde:
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
Danke für Ihr Feedback!