Rheinwerk Computing < openbook > Rheinwerk Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.
 
Inhaltsverzeichnis
Vorwort
1 Neues in Java 8 und Java 7
2 Fortgeschrittene String-Verarbeitung
3 Threads und nebenläufige Programmierung
4 Datenstrukturen und Algorithmen
5 Raum und Zeit
6 Dateien, Verzeichnisse und Dateizugriffe
7 Datenströme
8 Die eXtensible Markup Language (XML)
9 Dateiformate
10 Grafische Oberflächen mit Swing
11 Grafikprogrammierung
12 JavaFX
13 Netzwerkprogrammierung
14 Verteilte Programmierung mit RMI
15 RESTful und SOAP-Web-Services
16 Technologien für die Infrastruktur
17 Typen, Reflection und Annotationen
18 Dynamische Übersetzung und Skriptsprachen
19 Logging und Monitoring
20 Sicherheitskonzepte
21 Datenbankmanagement mit JDBC
22 Java Native Interface (JNI)
23 Dienstprogramme für die Java-Umgebung
Stichwortverzeichnis

Jetzt Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java SE 8 Standard-Bibliothek von Christian Ullenboom
Das Handbuch für Java-Entwickler
Buch: Java SE 8 Standard-Bibliothek

Java SE 8 Standard-Bibliothek
Pfeil 8 Die eXtensible Markup Language (XML)
Pfeil 8.1 Auszeichnungssprachen
Pfeil 8.1.1 Die Standard Generalized Markup Language (SGML)
Pfeil 8.1.2 Extensible Markup Language (XML)
Pfeil 8.2 Eigenschaften von XML-Dokumenten
Pfeil 8.2.1 Elemente und Attribute
Pfeil 8.2.2 Beschreibungssprache für den Aufbau von XML-Dokumenten
Pfeil 8.2.3 Schema – die moderne Alternative zu DTD
Pfeil 8.2.4 Namensraum (Namespace)
Pfeil 8.2.5 XML-Applikationen *
Pfeil 8.3 Die Java-APIs für XML
Pfeil 8.3.1 Das Document Object Model (DOM)
Pfeil 8.3.2 Simple API for XML Parsing (SAX)
Pfeil 8.3.3 Pull-API StAX
Pfeil 8.3.4 Java Document Object Model (JDOM)
Pfeil 8.3.5 JAXP als Java-Schnittstelle zu XML
Pfeil 8.3.6 DOM-Bäume einlesen mit JAXP *
Pfeil 8.4 Java Architecture for XML Binding (JAXB)
Pfeil 8.4.1 Bean für JAXB aufbauen
Pfeil 8.4.2 Utility-Klasse JAXB
Pfeil 8.4.3 Ganze Objektgraphen schreiben und lesen
Pfeil 8.4.4 JAXBContext und Marshaller/Unmarshaller nutzen
Pfeil 8.4.5 Validierung
Pfeil 8.4.6 Weitere JAXB-Annotationen *
Pfeil 8.4.7 Beans aus XML-Schema-Datei generieren
Pfeil 8.5 Serielle Verarbeitung mit StAX
Pfeil 8.5.1 Unterschiede der Verarbeitungsmodelle
Pfeil 8.5.2 XML-Dateien mit dem Cursor-Verfahren lesen
Pfeil 8.5.3 XML-Dateien mit dem Iterator-Verfahren verarbeiten *
Pfeil 8.5.4 Mit Filtern arbeiten *
Pfeil 8.5.5 XML-Dokumente schreiben
Pfeil 8.6 Serielle Verarbeitung von XML mit SAX *
Pfeil 8.6.1 Schnittstellen von SAX
Pfeil 8.6.2 SAX-Parser erzeugen
Pfeil 8.6.3 Operationen der Schnittstelle ContentHandler
Pfeil 8.6.4 ErrorHandler und EntityResolver
Pfeil 8.7 XML-Dateien mit JDOM verarbeiten
Pfeil 8.7.1 JDOM beziehen
Pfeil 8.7.2 Paketübersicht *
Pfeil 8.7.3 Die Document-Klasse
Pfeil 8.7.4 Eingaben aus der Datei lesen
Pfeil 8.7.5 Das Dokument im XML-Format ausgeben
Pfeil 8.7.6 Der Dokumenttyp *
Pfeil 8.7.7 Elemente
Pfeil 8.7.8 Zugriff auf Elementinhalte
Pfeil 8.7.9 Liste mit Unterelementen erzeugen *
Pfeil 8.7.10 Neue Elemente einfügen und ändern
Pfeil 8.7.11 Attributinhalte lesen und ändern
Pfeil 8.7.12 XPath
Pfeil 8.8 Transformationen mit XSLT *
Pfeil 8.8.1 Templates und XPath als Kernelemente von XSLT
Pfeil 8.8.2 Umwandlung von XML-Dateien mit JDOM und JAXP
Pfeil 8.9 XML-Schema-Validierung *
Pfeil 8.9.1 SchemaFactory und Schema
Pfeil 8.9.2 Validator
Pfeil 8.9.3 Validierung unterschiedlicher Datenquellen durchführen
Pfeil 8.10 Zum Weiterlesen
 
Zum Seitenanfang

8.8Transformationen mit XSLT * Zur vorigen ÜberschriftZur nächsten Überschrift

XSLT ist eine XML-Applikation zur Umwandlung von XML-Dateien in andere textbasierte Dateien. Die Ausgabedatei kann ein beliebiges Format haben. Die XSLT-Datei, in der Umwandlungsregeln festgelegt werden, muss ebenfalls eine XML-Datei sein. Das bedeutet insbesondere, dass HTML-Tags in der XSLT-Datei die Regeln für XML-Elemente erfüllen müssen.

 
Zum Seitenanfang

8.8.1Templates und XPath als Kernelemente von XSLT Zur vorigen ÜberschriftZur nächsten Überschrift

In der XSLT-Datei werden die Elemente der XML-Quelldatei durch Templates ausgewählt und wird die Formatierung der Ausgabe beschrieben. Es ist möglich, die Formatierung von Bedingungen abhängig zu machen, Elemente in der Ausgabe auszublenden und die Reihenfolge der Ausgabe festzulegen.

Die Auswahl der Elemente wird durch XPath-Ausdrücke beschrieben. XPath ist eine XML-Applikation, in der eine XML-Datei als Baumstruktur abgebildet wird. Durch eine Notation, die an die Baumstruktur von Verzeichnisbäumen angelehnt ist, können einzelne Elemente oder ganze Unterbäume ausgewählt werden.

Für unser Beispiel ist hier eine einfache XSLT-Datei angegeben, die eine XML-Ausgabe aus der Datei party.xml erzeugt. Dabei wird in dem ersten Template ein HTML-Rumpf erzeugt, in den die Ausgabe der anderen Templates eingebettet wird. Mit dem Element party wird eine Überschrift für die Ausgabedatei erzeugt. Das Element <gast> wird in einem Template benutzt, um für jeden Gast eine persönliche Anrede zu erzeugen. Jedem Gast wird sein Lieblingsgetränk serviert. Zum Schluss beschreibt noch jeder kurz, wie es ihm geht und ob er noch ledig ist. Hier ist die XSLT-Datei für die Umwandlung:

Listing 8.44party.xsl

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<!-- Match auf das Root-Element des XPath-Baums -->
<!-- Ausgabe von HTML-Kopf und -Fuss -->
<xsl:template match="/">
<html>
<head>
<title>Wir machen eine Party</title>
</head>
<body>
<!-- An dieser Stelle wird tiefer in den XPath-Baum -->
<!-- verzweigt. Die Ausgabe der anderen Templates -->
<!-- wird an dieser Stelle eingefuegt -->
<xsl:apply-templates />
</body>
</html>
</xsl:template>
<!-- Fuer das Element party der XML-Datei wird eine Ueberschrift -->
<!-- fuer die Ausgabe erzeugt. Das Attribut Datum wird in der -->
<!-- Ueberschrift ausgegeben. -->
<xsl:template match="party">
<h1>Partytabelle fuer den
<xsl:value-of select="@datum" />
</h1>
<xsl:apply-templates />
</xsl:template>
<!-- Fuer jeden einzelnen Gast wird eine Begruessung ausgegeben -->
<xsl:template match="gast">
<p>
<h2>Hallo
<xsl:value-of select="@name" />
</h2>
</p>
<xsl:apply-templates />
</xsl:template>
<!-- Jedem Gast wird sein Lieblingsgetraenk angeboten. -->
<xsl:template match="getraenk">
<p>Hier ist ein
<xsl:value-of select="." />
fuer dich.</p>
</xsl:template>
<!-- Hier wird eine bedingte Ausgabe erzeugt. Jeder Gast -->
<!-- zeigt seinen Zustand und sagt, ob er noch ledig ist. -->
<xsl:template match="zustand">
<xsl:if test="@nuechtern=’true’">
<h3>Ich bin noch nuechtern!</h3>
</xsl:if>
<xsl:if test="@ledig=’true’">
<h3>Ich bin noch zu haben!</h3>
</xsl:if>
<hr />
</xsl:template>
</xsl:stylesheet>

Das Ergebnis der Umwandlung ist folgende HTML-Datei:

<html>
<head>
<title>Wir machen eine Party</title>
</head>
<body>
<h1>Partytabelle fuer den 31.12.12</h1>
<p><h2>Hallo Albert Angsthase</h2></p>
<p>Hier ist ein Wein fuer dich.</p>
<p>Hier ist ein Bier fuer dich.</p>
<h3>Ich bin noch zu haben!</h3>
<hr>
<p><h2>Hallo Martina Mutig</h2></p>
<p>Hier ist ein Apfelsaft fuer dich.</p>
<h3>Ich bin noch nuechtern!</h3>
<h3>Ich bin noch zu haben!</h3>
<hr>
<p><h2>Hallo Zacharias Zottelig</h2></p>
</body>
</html>

Die Ausgabe des Parsers ist nicht so schön formatiert, aber das ist für die Ausgabe in HTML nicht relevant. Diese Datei wurde nachträglich formatiert, damit die Ausgabe besser lesbar ist. Trotz der Definition des Zeichensatzes im Kopf der XSLT-Datei sind Umlaute immer noch ein Problem.

 
Zum Seitenanfang

8.8.2Umwandlung von XML-Dateien mit JDOM und JAXP Zur vorigen ÜberschriftZur nächsten Überschrift

Damit die Umwandlung mit JDOM möglich ist, wird das JDOM-Dokument von einem Wrapper-Objekt aufgenommen und mit einem XSLT-Parser von JAXP umgewandelt. Das Ergebnis ist ein Wrapper-Objekt und kann in eine JDOM-Datenstruktur umgewandelt werden:

Listing 8.45com/tutego/insel/xml/xslt/XslTransformer.java, main()

Document doc = new SAXBuilder().build( "party.xml" );
Source xmlFile = new JDOMSource( doc );
JDOMResult htmlResult = new JDOMResult();
Transformer transformer =
TransformerFactory.newInstance().newTransformer(
new StreamSource("party.xsl") );
transformer.transform( xmlFile, htmlResult );
XMLOutputter xmlOutputter = new XMLOutputter();
xmlOutputter.output( doc, System.out );
xmlOutputter.output( htmlResult.getDocument(), System.out );

Das JDOM-Dokument doc wird vom Objekt xmlFile vom Typ JDOMSource ummantelt, das ein javax.xml.transform.Source ist. Das Ergebnis der Transformation nimmt ein JDOMResult-Objekt entgegen, das vom Typ javax.xml.transform.Result ist.

Eine Fabrikmethode der TransformerFactory erzeugt ein Objekt der Klasse Transformer. Dies ist ein Objekt aus dem JAXP-Paket, und es übernimmt die Umwandlung von XML-Dateien mithilfe einer XSLT-Datei. Für die Ein- und Ausgabe können Streams, SAX-Eigenschaften oder eine DOM-Datenstruktur verwendet werden. In diesem Beispiel wird die Datei als Stream an den Transformer übergeben. Mit dem Transformer-Objekt und einem Source- und Result-Objekt aus JAXP stößt transform(…) die Übersetzung an.

Das Ergebnis der Umwandlung steht in unserem JDOMResult-Objekt, und die Methode getDocument() wandelt es wieder in eine JDOM-Datenstruktur um.

Dieses Beispiel zeigt das Zusammenspiel von JDOM und JAXP. JDOM ist kein Ersatz für JAXP, sondern bietet eine komfortable Möglichkeit, XML-Dateien mit einer gewohnten Java-API zu verarbeiten. Dabei können Elemente aus JAXP, die nicht in JDOM implementiert sind, genutzt werden, ohne auf die Vorteile von JDOM zu verzichten.

 


Ihre Meinung

Wie hat Ihnen das Openbook gefallen? Wir freuen uns immer über Ihre Rückmeldung. Schreiben Sie uns gerne Ihr Feedback als E-Mail an kommunikation@rheinwerk-verlag.de.

<< zurück
 Zum Rheinwerk-Shop
Zum Rheinwerk-Shop: Java SE 8 Standard-Bibliothek Java SE 8 Standard-Bibliothek
Jetzt Buch bestellen

 Buchempfehlungen
Zum Rheinwerk-Shop: Java ist auch eine Insel
Java ist auch eine Insel


Zum Rheinwerk-Shop: Professionell entwickeln mit Java EE 8
Professionell entwickeln mit Java EE 8


Zum Rheinwerk-Shop: Besser coden
Besser coden


Zum Rheinwerk-Shop: Entwurfsmuster
Entwurfsmuster


Zum Rheinwerk-Shop: IT-Projektmanagement
IT-Projektmanagement


 Lieferung
Versandkostenfrei bestellen in Deutschland, Österreich und der Schweiz
InfoInfo

 
 


Copyright © Rheinwerk Verlag GmbH 2018
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das Openbook denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt.
Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.

 
Nutzungsbestimmungen | Datenschutz | Impressum

Rheinwerk Verlag GmbH, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, service@rheinwerk-verlag.de

Cookie-Einstellungen ändern