AJAX und JSON
Aus ProgrammingWiki
Wissen | Können | Projekt |
---|---|---|
|
|
|
Wie bereits im Kapitel HTTP erwähnt handelt es sich bei HTTP um ein Request-Response-Protokoll. Jede einzelne Kommunikation ist abgeschlossen und besteht immer aus dem Aufbauen der Verbindung, dem Senden der Anfragedaten, dem Empfang der Ergebnisdaten und dem Schließen der Verbindung. Dieser Prozess benötigt Zeit die zum Großteil für die Übertragung und serverseitige Operationen aufgewendet wird. Eine Client-Anwendung bleibt an dieser Stelle nichts anderes übrig als zu warten.
Im Kapitel Javascript 2 wurde bereits das Problem von wartenden Prozessen erörtert und festgestellt, dass zu lange Wartezeiten den Browser blockieren. Mit der asynchronen Programmierung wurde aber auch eine Technik vorgestellt, die diesem Problem entgegentritt. AJAX (Asynchronous Javascript And Xml) nutzt genau diese Technik indem Callback-Funktionen zur Verarbeitung des Anfrageergebnisses asynchron ausgeführt werden.
AJAX mit Javascript
Javascript stellt für die HTTP-Kommunikation das XMLHttpRequest Objekt bereit. Mit der Funktion open wird die Verbindung initiiert und send löst das Senden des Request aus. Beide Funktionen akzeptieren diverse Parameter zur Steuerung der Kommunikation. Für die Reaktion auf Serverantworten stehen entsprechende Callback-Funktionen bereit.
|
|
Hinweis zum Missbrauch von Access keys, wie sie beispielsweise für fixer und Geoservice erforderlich sind
Prinzipiell ist die Access-key-Technologie ein Abrechnungsmodell, um einem Entwickler für die angefallene Nutzung eines Dienstes eine Rechnung stellen zu können, wenn es zu viel wird.
Wenn man in das html schaut, steht der access key häufig sichtbar im code. Das ist systembedingt bei rich client Applikationen nötig. Deshalb beschränkt man dann beim anderen Dienst den key auf einen bestimmten referrer. Somit akzeptiert die Gegenstelle die Anfrage nur, wenn sie von einer vorher definierten Domain kommt. Der Browser schickt bei jeder Anfrage den referrer mit.
Den refferer kann man auch faken, somit ist das nicht 100% sicher, aber man kann den key nicht einfach in einer andere Webapplikation verwenden, wo ganz normale Leute mit ihrem normalen Browser drauf gehen. Damit reicht das in der Regel, um Missbrauch zu verhindern.
AJAX mit jQuery
Mit jQuery werden Funktionen bereitgestellt, die das Javascript XMLHttpRequest Objekt kapseln und die gleiche Funktionalität bieten. Jedoch wird hier eine andere Syntax für den Aufruf verwendet, so dass dieser als eine einzige Funktion definiert werden kann. Sämtliche Aufrufparameter, inklusive der Callback-Funktionen, werden hier als Eigenschaften eines Objekts an die Funktion übergeben. Die möglichen Eigenschaftsnamen (Parameter) können in der jQuery-Dokumentation nachgelesen werden.
|
|
Weiterführende Inhalte
XMLHttpRequest mit PHP und JSON - Zeigt die Verwendung der modernen XMLHttpRequest mit einem PHP-Backend und wie man mit JSON-Antworten arbeitet.
XMLHttpRequest - Beschreibung des XMLHttpRequest-Standards, API-Dokumentation und Beispiele
JSFiddle mit Fetch - Beispiel für die Anwendung von der auf einem Promise basierenden fetch-Methode
Serialisierung
Um auch Objekte, die sich ausschließlich im Arbeitsspeicher befinden, übertragen zu können, müssen diese serialisiert (in eine sequentiell übertragbare Struktur gebracht) werden. Für Javascript Objekte ist die Javascript Object Notation (JSON) eine solche Struktur. Mit JSON.stringify kann ein Objekt in eine JSON-Zeichenkette überführt werden. Diese kann nun, wie jede andere Zeichenkette, übertragen werden. Die Erzeugung eines Javascript Objekts aus der JSON-Zeichenkette erfolgt mit JSON.parse. JSON ähnelt der Literaldefinition von Objekten in Javascript (eingefasst in geschweifte Klammern werden die Eigenschaften des Objekts durch Komma getrennt als Name-Wert-Paare aufgelistet). JSON ist aber sehr viel strikter. Neben Notationsunterschieden sind z.B. rekursive Objektreferenzen nicht serialisierbar.
|
|
Validierung
Sollen serialisierte Daten von externen Quellen deserialisiert werden, ist es ratsam diese vorher zu validieren, also deren korrekte Struktur zu verifizieren. Für XML-Daten gibt es dazu die XML Schema Definition (XSD). Es handelt sich hierbei um eine Beschreibung der Struktur eines gültigen XML-Dokuments. Neben Vorgaben zu den möglichen Elementen, Attributen und Inhalten sind auch Angaben zur Anzahl der Vorkommen und zu Verschachtelungsmöglichkeiten enthalten.
Eine Schema-Definition ist grundsätzliche in ein <xs:schema> Element eingefasst mit dem zugehörigen xmlns:xs Attribut zur Definition der zu verwendenden Schema-Spezifikation. Es kann zur Festlegung von Spezifikationsversionen und Namespaces um verschiedene Attribute erweitert werden. Mit <xs:element name="xxx"> wird das einmalige Vorhandensein eines Elements xxx erwartet. Mit dem Attribut type kann bei einfachem Inhalt der Typ des Inhalts festgelegt werden. Die Attribute minOccurs und maxOccurs ermöglichen es, die Anzahl der Vorkommen des Elements zu definieren. Werden am Element Attribute erwartet, so können diese mit <xs:attribute name="xyz"> im Inneren der Elementdefinition angegeben werden. Komplexe Elemente können mit <xs:complexType name="yyy"> definiert werden. Unterelemente werden hier, je nach Relevanz von Reihenfolge und Anzahl des Auftretens, in <xs:sequence>, <xs:choice> oder <xs:all> eingefasst. Die Struktur des Schemas entspricht dabei der erwarteten Struktur des XML-Dokuments.
Neben diesen grundlegenden Spezifikationen gibt es viele weitere Möglichkeiten. Dazu zählen Restriktionen für einfache Elemente (wenn. z.B. nur bestimmte Zahlen oder bestimmte Wörter ermöglicht werden sollen), Referenzierungen (um wiederkehrende Elemente nicht mehrfach definieren zu müssen) und Erweiterungen (ein vorhandenes Element wird um zusätzliche Spezifikationen erweitert).
Schema (XSD) | Inhalt (XML) |
---|---|
- Experimentieren Sie mit dem Beispiel. Ändern Sie es, sodass die einzelnen Elemente art, name und alter in beliebiger Reihenfolge angegeben werden können.
- Ermöglichen Sie, dass mehrere Tiere in XML definiert werden können und sichern sie ab, dass jedes Tier eine id hat
- Stellen Sie sicher, dass nur Altersangaben größer oder gleich 0 definiert werden können
- Ändern Sie die Schema-Definition, so dass nur die Tierarten Hund, Katze und Vogel verwendet werden dürfen
- Stellen Sie sicher, dass jedes Tier eine unterschiedliche id hat
- Zu jedem Tier sollen dessen Tierarztbesuche erfasst werden. Bedenken Sie, dass Tierarztbesuche beliebig häufig stattfinden können. Das Datum des Arztbesuches soll als Attribut definiert werden und der Grund als freier Text innerhalb des entsprechenden Elements
- Anstelle des allgemeinen Tags tier sollen für jede Art spezielle Tags genutzt werden. Benutzen Sie die tier-Spezifikationen für die neuen Elemente hund, katze und vogel. Prüfen Sie ob die Sicherstellung der eindeutigen id noch funktioniert und passen Sie diese ggf. an.
Projekt und weitere Übungen
Stellen Sie die Anmeldung auf Node.js um. Speichern Sie zusätzlich zu jedem Nutzer seine Ergebnisse (benötigte Zeit zur Lösung eines Sudokus) und geben Sie diese in der Webapplikation aus.
Beispiellösung![]() | WE1-P8.zip (0.8 MB) |
- Analysieren Sie das folgende Dokument mit Firebug.
- Arbeiten Sie den online-Beitrag über die Verarbeitung großer Datenmengen (im JSON-Format) durch und implementieren Sie die genannten Strategien. Bewerten Sie das jeweilige Ergebnis.
- Verwenden Sie einen sniffer, z.B. Fiddler (kostenlos), um die Datenkommunikation zwischen Client und Server zu beobachten und zu interpretieren. Als HTTP-Debugging-Proxy platziert sich Fiddler zwischen dem Client und dem (entfernten) Server, der die Anfrage entgegennimmt. Da ist es ein Leichtes, ein- und ausgehenden HTTP-Verkehr zu protokollieren - und zu ändern.
- Verwenden Sie den Geoservice von Google und stellen Sie damit interessante Daten tabellarisch zusammen.
- Erschließen Sie die (komfortablen) Methoden der AJAX-Verarbeitung von jQuery und kommentieren Sie ein selbsterstelltes Beispiel mit JSON-Daten.
- Bei Interesse: Verwenden Sie AtoCC zur Herstellung eines JSON-Parsers.