In der vierten Aufgabe sollen die Speicherung und Filterung von GeoTags nun aus dem Browser mittels Ajax erfolgen (statt dem Form-Mechanismus) und auf der Serverseite über eine REST-API realisiert werden.
Am Ende soll die Funktionalität der Anwendung identisch erhalten bleiben, nur dass die Interaktion mit dem Server per Ajax wesentlich schneller und ohne störenden Aufbau einer neuen Seite abläuft.
Die Aufgabe vertieft die Programmierung von Event-Listenern sowie die Verwendung der XMLHttpRequest API in Javascript. Zudem wird die Struktur von REST APIs sowie deren Umsetzung mit dem HTTP-Protokoll über Express Routen in Javascript eingeübt.
Aktualisieren Sie zunächst das Repository auf ihrem Entwicklungsrechner. Die Dateien der Aufgabe liegen im Ordner Aufgabe4
.
- Kopieren Sie das Stylesheet
Aufgabe1/gta_v1/public/stylesheets/style.css
aus Aufgabe 1 nachAufgabe4/gta_v4/public/stylesheets/style.css
. - Kopieren Sie das Client Skript
Aufgabe3/gta_v3/public/javascripts/geotagging.js
aus Aufgabe 3 nachAufgabe4/gta_v4/public/javascripts/geotagging.js
. - Kopieren Sie das Server Skript
Aufgabe3/gta_v3/gta-server.js
aus Aufgabe 3 nachAufgabe4/gta_v4/gta-server.js
. - Kopieren Sie das EJS-Template
Aufgabe3/gta_v3/views/gta.ejs
aus Aufgabe 3 nachAufgabe4/gta_v4/views/gta.ejs
.
- Führen sie
npm install
im VerzeichnisAufgabe4/gta_v4/
aus, um die nötigen Module zu laden und zu installieren. - Um die App später zu starten führen sie
npm start
im VerzeichnisAufgabe4/gta_v4/
aus und öffnen sie http://localhost:3000 im Browser.
Die Umstellung auf Ajax Aufrufe und REST Schnittstelle betrifft Client- und Serverseite.
Für den Ajax Aufruf im Browser müssen Sie ihr Javascript Aufgabe4/gta_v4/public/javascripts/geotagging.js
weiter anpassen.
Die Formulare für die Eingabe und das Filtern von Tags können grundsätzlich beibehalten werden, jedoch soll jeweils beim Klicken des Buttons ein Ajax Aufruf erfolgen. Hierzu müssen Sie beim Laden der Seite Event-Listener erstellen und registrieren. Dies sollte direkt nach dem Laden einer Seite erfolgen.
Um das standardmäßige Absenden der Formulare zu verhindern, kann ein anderer Button-Typ verwendet werden (im EJS-Template für die button
- Elemente type
-Attribut submit
durch button
ersetzen).
Der Ajax Aufruf soll mit dem XMLHttpRequest Objekt realisiert werden (siehe entsprechende Folien).
- Für das Tagging Formular soll der Aufruf asynchron ablaufen und die Daten per HTTP POST in JSON Format an den Server senden.
- Tipp 1: Sie können hier den serverseitigen GeoTag Konstruktor aus Aufgabe 3 clientseitig wiederverwenden.
- Tipp 2: spezifizieren sie einen JSON MIME-Typ im HTTP-Header
Content-Type
, damit der Server den Inhalt erkennt.
- Für das Filter Formular soll der Aufruf auch asynchron ablaufen aber per HTTP GET mit Query Parametern erfolgen.
Auf der Clientseite muss noch eine Funktion zur Aktualisierung der Darstellung im Discovery-Widget erstellt werden. Diese soll die Ergebnisliste (und optional die Karte) aktualisieren. Die Aktualisierung soll sowohl beim Anlegen eines neuen Filters als auch eines neuen GeoTags erfolgen.
Für die REST-Schnittstelle auf der Serverseite kann das Skript gta-server.js
weiterentwickelt werden. Hier müssen neue Routen für die Ajax Aufrufe erstellt werden (die bisherigen Routen können dabei beibehalten werden).
In einer REST-konformen API besitzen Ressourcen eines Typs (also z.B. GeoTag) oft eine sog. Container-Ressource, die im URI-Pfad nach dem Plural der Ressource benannt ist (also z.b. /geotags
). Das Erzeugen einer neuen Ressourcen-Instanz erfolgt dann per HTTP POST auf die Adresse der Container Ressource. Das Auslesen aller Ressourcen-Instanzen erfolgt durch HTTP GET auf die Adresse der Container Ressource. Realisieren sie zwei entsprechende Routen.
Einzelne Ressourcen-Instanzen sind in einer REST-API über eine individuelle URI direkt zugreifbar. Diese Adresse folgt oft dem Schema <Container-Ressource>/<Ressourcen-ID>
(also z.B. geotags/123
). Beim Erzeugen einer neuen Ressourcen-Instanz per HTTP POST sollte am Ende deren URI im Location
HTTP-Header zurückgesendet werden. Der HTTP Response Code ist 201
(Created).
Sie sollten auch noch eine Route hinzufügen, die das Auslesen einzelner GeoTag-Ressourcen per HTTP GET ermöglicht.
Die Vorverarbeitung des HTTP Requests erfolgt mit dem Modul Bodyparser. Stellen Sie sicher, dass der Bodyparser (auch) für die Verarbeitung von JSON-Inhalten konfiguriert ist. Der JSON-Inhalt lässt sich dann aus dem Body des Request Objekts entnehmen.