MEAN.JS - REST-API
In diesem Kapitel sehen wir, wie unsere Anwendung mithilfe von HTTP-Methoden über eine REST-API mit unserer Datenbank interagiert. Der Begriff REST steht für REpresentational State Transfer, einen Architekturstil für die Kommunikation mit Webdiensten, und API steht für Application Program Interface, das die Interaktion von Anwendungen untereinander ermöglicht.
Zuerst erstellen wir eine RESTful-API, um alle Elemente abzurufen, das Element zu erstellen und ein Element zu löschen. Für jedes Element wird _id automatisch von MongoDB generiert. In der folgenden Tabelle wird beschrieben, wie die Anwendung Daten von der API anfordern soll.
HTTP-Methode | URL-Pfad | Beschreibung |
---|---|---|
BEKOMMEN | /api/students | Es wird verwendet, um alle Schüler aus der Sammlung Student zu erhalten. |
POST | /api/students/send | Es wird verwendet, um einen Studentendatensatz in der Sammlung Student zu erstellen. |
LÖSCHEN | /api/students/student_id | Es wird verwendet, um einen Schülerdatensatz aus der Sammlung Student zu löschen. |
RESTful API-Routen
Wir werden zuerst die Post-Methode in RESTful-API-Routen diskutieren.
POST
Lassen Sie uns zunächst über unsere REST-API einen Datensatz in der Sammlung Student erstellen. Der Code für diesen speziellen Fall befindet sich in der Datei server.js . Als Referenz wird hier ein Teil des Codes eingefügt -
app.post('/api/students/send', function (req, res) {
var student = new Student(); // create a new instance of the student model
student.name = req.body.name; // set the student name (comes from the request)
student.save(function(err) {
if (err)
res.send(err);
res.json({ message: 'student created!' });
});
});
Ausführung
Sie können den Quellcode für diese Anwendung unter diesem Link herunterladen . Laden Sie die Zip-Datei herunter. Extrahieren Sie es in Ihrem System. Öffnen Sie das Terminal und führen Sie den folgenden Befehl aus, um die Abhängigkeiten des npm-Moduls zu installieren.
$ cd mean-demon-consuming_rest_api
$ npm install
Um die Anfrage zu analysieren, benötigen wir ein Body-Parser-Paket. Führen Sie daher den folgenden Befehl aus, um ihn in Ihre Anwendung aufzunehmen.
npm install --save body-parser
Der angehängte Quellcode hat bereits diese Abhängigkeit, daher muss der obige Befehl nicht ausgeführt werden, sondern dient nur zu Ihrer Information.
Navigieren Sie zum Ausführen der Anwendung zu Ihrem neu erstellten Projektverzeichnis und führen Sie den folgenden Befehl aus:
npm start
Sie erhalten eine Bestätigung wie im Bild unten gezeigt -
Es gibt viele Tools zum Testen der API-Aufrufe. Hier verwenden wir eine der benutzerfreundlichen Erweiterungen für Chrome namens Postman REST Client .
Öffnen Sie den Postman REST Client und geben Sie die URL als ein http://localhost:3000/api/students/sendWählen Sie die POST-Methode . Geben Sie als Nächstes die Anforderungsdaten wie unten gezeigt ein -
Beachten Sie, dass wir die Namensdaten als x-www-form-urlencoded senden . Dadurch werden alle unsere Daten als Abfragezeichenfolgen an den Knotenserver gesendet.
Klicken Sie auf die Schaltfläche Senden , um einen Schülerdatensatz zu erstellen. Eine Erfolgsmeldung wird wie folgt angezeigt:
BEKOMMEN
Als nächstes holen wir uns alle Schülerdaten aus dem Mongodb. Die folgende Route muss geschrieben werden. Den vollständigen Code finden Sie in der Datei server.js .
app.get('/api/students', function(req, res) {
// use mongoose to get all students in the database
Student.find(function(err, students) {
// if there is an error retrieving, send the error.
// nothing after res.send(err) will execute
if (err)
res.send(err);
res.json(students); // return all students in JSON format
});
});
Öffnen Sie als Nächstes den Postman REST Client und geben Sie die URL als ein
http://localhost:3000/api/studentsWählen Sie die GET- Methode und klicken Sie auf die Schaltfläche Senden, um alle Schüler abzurufen.
LÖSCHEN
Als nächstes sehen wir uns an, wie Sie einen Datensatz aus unserer Mongo-Sammlung über den REST-API-Aufruf löschen.
Die folgende Route muss geschrieben werden. Den vollständigen Code finden Sie in der Datei server.js .
app.delete('/api/students/:student_id', function (req, res) {
Student.remove({
_id: req.params.student_id
}, function(err, bear) {
if (err)
res.send(err);
res.json({ message: 'Successfully deleted' });
});
});
Öffnen Sie als Nächstes den Postman REST Client und geben Sie die URL als ein
http://localhost:3000/api/students/5d1492fa74f1771faa61146d
(hier ist 5d1492fa74f1771faa61146d der Datensatz, den wir aus der Sammlung Student löschen werden).
Wählen Sie die DELETE- Methode und klicken Sie auf die Schaltfläche Senden , um alle Schüler abzurufen.
Sie können die MongoDB auf gelöschte Daten überprüfen, indem Sie GET aufrufen http://localhost:3000/api/students/5d1492fa74f1771faa61146d.