Dietmar Abts Masterkurs Client/Server- Programmierung mit Java Anwendungen entwickeln mit Standard-Technologien 5. Auflage Masterkurs Client/Server-Programmierung mit Java Dietmar Abts Masterkurs Client/Server- Programmierung mit Java Anwendungen entwickeln mit Standard- Technologien 5. Auflage Dietmar Abts FB Wirtschaftswissenschaften Hochschule Niederrhein Mönchengladbach, Deutschland Ergänzendes Material zu diesem Buch finden Sie auf http://extras.springer.com. ISBN 978-3-658-25924-2 ISBN 978-3-658-25925-9 (eBook) https://doi.org/10.1007/978-3-658-25925-9 Die Deutsche Nationalbibliothek verzeichnet diese Publikation in der Deutschen Nationalbibliografie; detail- lierte bibliografische Daten sind im Internet über http://dnb.d-nb.de abrufbar. Springer Vieweg 1. Auflage 2003 erschien unter dem Titel „Aufbaukurs JAVA“ 2. Auflage 2007 erschien unter dem Titel „Masterkurs JAVA“ © Springer Fachmedien Wiesbaden GmbH, ein Teil von Springer Nature 2003, 2007, 2010, 2015, 2019 Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Jede Verwertung, die nicht ausdrücklich vom Urheberrechtsgesetz zugelassen ist, bedarf der vorherigen Zustimmung des Verlags. Das gilt insbesondere für Vervielfältigungen, Bearbeitungen, Übersetzungen, Mikroverfilmungen und die Einspeicherung und Verarbeitung in elektronischen Systemen. Die Wiedergabe von allgemein beschreibenden Bezeichnungen, Marken, Unternehmensnamen etc. in diesem Werk bedeutet nicht, dass diese frei durch jedermann benutzt werden dürfen. Die Berechtigung zur Benutzung unterliegt, auch ohne gesonderten Hinweis hierzu, den Regeln des Markenrechts. Die Rechte des jeweiligen Zeicheninhabers sind zu beachten. Der Verlag, die Autoren und die Herausgeber gehen davon aus, dass die Angaben und Informationen in diesem Werk zum Zeitpunkt der Veröffentlichung vollständig und korrekt sind. Weder der Verlag, noch die Autoren oder die Herausgeber übernehmen, ausdrücklich oder implizit, Gewähr für den Inhalt des Werkes, etwaige Fehler oder Äußerungen. Der Verlag bleibt im Hinblick auf geografische Zuordnungen und Gebietsbezeichnungen in veröffentlichten Karten und Institutionsadressen neutral. Springer Vieweg ist ein Imprint der eingetragenen Gesellschaft Springer Fachmedien Wiesbaden GmbH und ist ein Teil von Springer Nature Die Anschrift der Gesellschaft ist: Abraham-Lincoln-Str. 46, 65189 Wiesbaden, Germany Vorwort zur 5. Auflage »Wir behalten von unsern Studien am Ende doch nur das, was wir praktisch anwenden.« J. W. von Goethe, zu Johann Peter Eckermann, 24. Februar 1824 Das vorliegende Buch bietet eine Einführung in Standard-Technologien zur Ent- wicklung von modernen Client/Server-Anwendungen auf der Basis von Java SE mit zahlreichen Programmbeispielen (56 Java-Projekte) und 45 Übungsaufgaben. Alle Projekte, die Lösungen zu den Aufgaben und die benötigten Bibliotheken sind als Download verfügbar (siehe Kapitel 1.2.3). Gegenüber der vorhergehenden Auflage wurden zahlreiche Verbesserungen und Aktualisierungen vorgenommen sowie neue Aspekte aufgenommen. Insbesondere wurde das Kapitel zu den REST-basierten Web Services stark erweitert. In Verbindung mit HTML5, CSS3 und Javascript sind insbesondere bei Single-Page- Webanwendungen und Progressive Web Apps REST-fähige Backends und die asynchrone Lieferung von Daten über das REST-API von großer Bedeutung. Die mit Java 9 als deprecated markierten Module sind in Java 11 nicht mehr vorhanden. Hierbei handelt es sich um Module und Frameworks, die insbesondere bei Java EE bzw. Jakarta EE eine Rolle spielen und auch in den Projekten des vorliegenden Buches gebraucht werden. Diese sind jedoch als separate Biblio- theken außerhalb des JDK verfügbar und können in die Projekte eingebunden werden. Die beigefügten Skripte zur Ausführung der Programme und die Beschreibungen hierzu im Buch berücksichtigen diese Tatsache. Alle Programmbeispiele wurden mit Java 11 und den zum Zeitpunkt der Drucklegung aktuellen Versionen der Bibliotheken ausführlich getestet. Die verschiedenen Themen des Buches können mit guten Java-Grundkenntnissen erarbeitet werden. Geeignete Zielgruppen sind Studierende der Informatik und Wirtschaftsinformatik, IT-Beschäftigte in Ausbildung und Beruf sowie Java- Programmierer in der Praxis. Danken möchte ich meinen Leserinnen und Lesern für die konstruktive Kritik und Frau Sybille Thelen, Lektorin des Verlags, für die stets gute Beratung und Zusam- menarbeit. Nun wünsche ich Ihnen viel Spaß beim Lesen und praktischen Erarbeiten der Themen. Ratingen, Februar 2019 Dietmar Abts [email protected] www.dietmar-abts.de Inhaltsverzeichnis 1 Einleitung.............................................................................................................1 1.1 Zielsetzung und Aufbau des Buches...................................................................1 1.2 Tools zur Entwicklung........................................................................................3 1.2.1 Java...........................................................................................................3 1.2.2 Entwicklungsumgebung............................................................................3 1.2.3 Materialien zum Buch...............................................................................4 1.3 Grundlagen Verteilter Systeme...........................................................................4 1.3.1 Definition Verteiltes System......................................................................5 1.3.2 Vor- und Nachteile Verteilter Systeme.......................................................6 1.3.3 Das Client/Server-Modell..........................................................................7 1.3.4 Systemarchitekturen..................................................................................9 1.3.5 Ziele Verteilter Systeme..........................................................................12 1.4 Grundlagen zu TCP/IP.....................................................................................14 1.4.1 Das Schichtenmodell...............................................................................14 1.4.2 IP-Adressen, DNS und Ports...................................................................16 1.5 Java-Klassen für IP-Adressen und Sockets.......................................................19 1.6 Aufgaben..........................................................................................................22 2 Datenaustausch mit JSON................................................................................23 2.1 Java API for JSON Binding..............................................................................24 2.2 Serialisierung eines Objektgraphs....................................................................30 2.3 Aufgaben..........................................................................................................35 3 Kommunikation mit UDP.................................................................................37 3.1 Das Protokoll UDP...........................................................................................37 3.2 DatagramSocket und DatagramPacket.............................................................38 3.3 Nachrichten senden und empfangen.................................................................41 3.4 Anfrage und Antwort........................................................................................44 3.5 Punkt-zu-Mehrpunkt-Verbindungen.................................................................48 3.6 Aufgaben..........................................................................................................51 4 Netzwerkprogrammierung mit TCP-Sockets..................................................53 4.1 Das Protokoll TCP...........................................................................................53 4.2 TCP-Sockets.....................................................................................................54 4.3 Iterative und parallele Server............................................................................58 4.3.1 Iterativer Server.......................................................................................58 VIII Inhaltsverzeichnis 4.3.2 Paralleler Server......................................................................................62 4.3.3 Thread-Pooling........................................................................................64 4.4 Ein Framework für TCP-Server.......................................................................67 4.5 Beenden eines Datenstroms..............................................................................71 4.6 Ein Chat-Programm..........................................................................................73 4.7 Asynchrone Kommunikation............................................................................81 4.8 Aufgaben..........................................................................................................87 5 Nachrichtentransfer mit JMS...........................................................................89 5.1 Java Message Service.......................................................................................90 5.2 Das Point-to-Point-Modell...............................................................................93 5.2.1 Installation und Konfiguration von ActiveMQ........................................93 5.2.2 Wichtige Typen und Methoden des JMS-API..........................................95 5.2.3 Das Pull- und Push-Prinzip.....................................................................97 5.2.4 Der QueueBrowser................................................................................102 5.3 Das Request/Reply-Modell............................................................................105 5.4 Das Publish/Subscribe-Modell.......................................................................108 5.5 Dauerhafte Subscriber....................................................................................111 5.6 Nachrichten filtern..........................................................................................114 5.7 Transaktionen.................................................................................................117 5.8 Aufgaben........................................................................................................121 6 Remote Method Invocation............................................................................123 6.1 Vom lokalen zum entfernten Methodenaufruf................................................123 6.2 Die Architektur einer RMI-Anwendung.........................................................126 6.2.1 Protokoll und Komponenten..................................................................126 6.2.2 Implementierungsvarianten...................................................................133 6.2.3 Dienstauskunft.......................................................................................134 6.2.4 Aufrufparameter und Rückgabewerte....................................................135 6.3 Übertragung von Remote Objects..................................................................136 6.4 Mobile Agenten..............................................................................................140 6.5 Der Einsatz von Callback-Methoden..............................................................143 6.6 Aufgaben........................................................................................................149 7 Kommunikation über HTTP..........................................................................153 7.1 Die Protokolle HTTP/1.0 und HTTP/1.1........................................................153 7.2 Ein einfacher Webserver.................................................................................162 7.3 Ein Monitor für Anfragen und Antworten......................................................170 Inhaltsverzeichnis IX 7.4 Ein einfacher Webserver mit CRUD-Operationen..........................................174 7.5 HTTP/2 und SSL/TLS im Beispiel.................................................................182 7.6 Aufgaben........................................................................................................188 8 Bidirektionale Verbindung mit WebSocket...................................................191 8.1 Das WebSocket-Protokoll...............................................................................191 8.2 Eine einfache WebSocket-Anwendung...........................................................193 8.3 Server-Push....................................................................................................199 8.4 Eine Chat-Anwendung...................................................................................203 8.5 Aufgaben........................................................................................................206 9 SOAP-basierte Web Services mit JAX-WS...................................................209 9.1 Grundlagen.....................................................................................................209 9.2 Ein erstes Beispiel..........................................................................................215 9.3 Ein Web Service mit CRUD-Operationen......................................................220 9.4 Web Services mit Apache Tomcat veröffentlichen.........................................225 9.5 Oneway-Operationen......................................................................................226 9.6 Asynchrone Aufrufe.......................................................................................228 9.7 Transport von Binärdaten...............................................................................232 9.8 Filterketten.....................................................................................................239 9.9 Contract First..................................................................................................251 9.10 Aufgaben......................................................................................................256 10 REST-basierte Web Services mit JAX-RS...................................................259 10.1 Die Grundprinzipien von REST...................................................................259 10.2 Ein erstes Beispiel........................................................................................262 10.2.1 Die erforderlichen Bibliotheken..........................................................262 10.2.2 Der Web Service..................................................................................263 10.2.3 Test mit cURL.....................................................................................271 10.2.4 Die Beschreibungssprache WADL......................................................273 10.2.5 Ein Java-Client....................................................................................275 10.2.6 Das Client-API von JAX-RS...............................................................279 10.3 CRUD-Operationen mit Datenbank..............................................................282 10.4 REST-Services mit Apache Tomcat veröffentlichen.....................................294 10.5 Upload und Download von Dateien..............................................................295 10.6 Zuverlässigkeit.............................................................................................300 10.6.1 PUT statt POST...................................................................................300 10.6.2 Kombination von POST und PUT.......................................................304 X Inhaltsverzeichnis 10.7 Parallelzugriffe.............................................................................................307 10.8 Caching........................................................................................................313 10.8.1 Expirationsmodell...............................................................................315 10.8.2 Validierungsmodell..............................................................................317 10.9 Asynchrone Verarbeitung.............................................................................321 10.9.1 Polling.................................................................................................321 10.9.2 Callback..............................................................................................327 10.9.3 Client/Server-API für asynchrone Verarbeitung..................................331 10.10 Server-Sent Events (SSE)...........................................................................337 10.11 Filterketten.................................................................................................345 10.12 Rollenbasierter Zugriffsschutz und Verschlüsselung..................................354 10.13 Aufgaben....................................................................................................363 Anhang A Tools und Bibliotheken.....................................................................................371 B Globale Bibliotheken in IntelliJ IDEA..............................................................375 C IntelliJ-IDEA-Projekte in Eclipse-Projekte konvertieren..................................377 Literaturhinweise..................................................................................................379 Sachwortverzeichnis............................................................................................381 1 Einleitung In diesem Kapitel erfahren Sie zunächst, was Sie von diesem Buch erwarten können, welche Themen behandelt werden und wie es aufgebaut ist. Es folgen Hinweise zu vorausgesetzten Kenntnissen, zur verwendeten Entwicklungsum- gebung und zu den zur Verfügung gestellten Quellcodes und Tools. Des Weiteren erfahren Sie, was man unter einem verteilten System versteht, und lernen Grundlagen zu TCP/IP, zu IP-Adressen und Sockets kennen. 1.1 Zielsetzung und Aufbau des Buches Das vorliegende Buch beschäftigt sich mit der Implementierung von Client/Server- Anwendungen auf Basis der Internet-Protokolle und der darauf aufsetzenden Standard-Technologien. Die dazu gehörenden Spezifikationen sind zum großen Teil unabhängig von der verwendeten Programmiersprache (wie z. B. bei HTTP, WebSocket, SOAP- und REST-basierten Web Services). Wir nutzen für die Implementierung der Beispiele durchweg Java und bekannte Referenzimplemen- tierungen der oben angesprochenen Spezifikationen. Angesichts des Umfangs der Themen musste eine Auswahl getroffen werden, die beispielsweise in einem vier Semesterwochenstunden umfassenden Kurs behandelt werden kann. Zielsetzung Ziel des Buches ist es, über die Themenvielfalt angemessen zu informieren und in die Einzelthemen systematisch mit der für die Anwendungsentwicklung nötigen Tiefe einzuführen. Besonderer Wert wurde dabei auf praxisnahe Programm- beispiele und Übungsaufgaben gelegt. Die Technologien JMS (für die asynchrone Nachrichtenverarbeitung), WebSocket (verwendet, um aus serverseitig laufenden Java-Programmen Nachrichten an Clients zu senden), JAX-WS (hilft bei der Erstellung von Web Services und zugehörigen Clients, die über SOAP kommunizieren) und JAX-RS (verwendet den Architekturstil REST im Rahmen von Web Services) sind Teil der Enterprise- Edition Java EE. Sie werden hier stand-alone verwendet. Aufbau des Buches Dieses Buch ist in zehn Kapitel gegliedert, die jeweils einen Schwerpunkt behandeln. Obwohl die Kapitel weitestgehend in sich geschlossen sind und unabhängig voneinander bearbeitet werden können, wird empfohlen, diese in der hier vorgegebenen Reihenfolge durchzuarbeiten, da in manchen Abschnitten auf frühere Kapitel verwiesen wird. Die vorgestellten Themen werden anhand vollstän- diger, lauffähiger Programmbeispiele verdeutlicht. Übungsaufgaben am Ende eines jeden Kapitels regen zur selbständigen Beschäftigung mit dem dargebotenen Stoff an. © Springer Fachmedien Wiesbaden GmbH, ein Teil von Springer Nature 2019 D. Abts, Masterkurs Client/Server-Programmierung mit Java, https://doi.org/10.1007/978-3-658-25925-9_1