Galileo Computing < openbook > Galileo Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort
1 Java ist auch eine Sprache
2 Sprachbeschreibung
3 Klassen und Objekte
4 Der Umgang mit Zeichenketten
5 Mathematisches
6 Eigene Klassen schreiben
7 Angewandte Objektorientierung
8 Exceptions
9 Generics, innere Klassen
10 Die Klassenbibliothek
11 Threads und nebenläufige Programmierung
12 Datenstrukturen und Algorithmen
13 Raum und Zeit
14 Dateien und Datenströme
15 Die eXtensible Markup Language (XML)
16 Grafische Oberflächen mit Swing
17 Grafikprogrammierung
18 Netzwerkprogrammierung
19 Verteilte Programmierung mit RMI und Web–Services
20 JavaServer Pages und Servlets
21 Applets
22 Midlets und die Java ME
23 Datenbankmanagement mit JDBC
24 Reflection und Annotationen
25 Logging und Monitoring
26 Sicherheitskonzepte
27 Java Native Interface (JNI)
28 Dienstprogramme für die Java-Umgebung
Stichwort

Download:
- ZIP, ca. 14,1 MB
Buch bestellen
Ihre Meinung?

Spacer
<< zurück
Java ist auch eine Insel (8. Auflage) von Christian Ullenboom
Programmieren mit der Java Standard Edition Version 6
Buch: Java ist auch eine Insel (8. Auflage)

Java ist auch eine Insel (8. Aufl.)
8., aktual. Auflage, geb., mit DVD
1.475 S., 49,90 Euro
Galileo Computing
ISBN 978-3-8362-1371-4
Pfeil 15 Die eXtensible Markup Language (XML)
Pfeil 15.1 Auszeichnungssprachen
Pfeil 15.1.1 Die Standard Generalized Markup Language (SGML)
Pfeil 15.1.2 Extensible Markup Language (XML)
Pfeil 15.2 Eigenschaften von XML-Dokumenten
Pfeil 15.2.1 Elemente und Attribute
Pfeil 15.2.2 Beschreibungssprache für den Aufbau von XML-Dokumenten
Pfeil 15.2.3 Schema – eine Alternative zu DTD
Pfeil 15.2.4 Namensraum (Namespace)
Pfeil 15.2.5 XML-Applikationen
Pfeil 15.3 Die Java-APIs für XML
Pfeil 15.3.1 Das Document Object Model (DOM)
Pfeil 15.3.2 Simple API for XML Parsing (SAX)
Pfeil 15.3.3 Pull-API StAX
Pfeil 15.3.4 Java Document Object Model (JDOM)
Pfeil 15.3.5 JAXP als Java-Schnittstelle zu XML
Pfeil 15.3.6 DOM-Bäume einlesen mit JAXP
Pfeil 15.4 Serielle Verarbeitung mit StAX
Pfeil 15.4.1 Unterschiede der Verarbeitungsmodelle
Pfeil 15.4.2 XML-Dateien mit dem Cursor-Verfahren lesen
Pfeil 15.4.3 XML-Dateien mit dem Iterator-Verfahren verarbeiten
Pfeil 15.4.4 Mit Filtern arbeiten
Pfeil 15.4.5 XML-Dokumente schreiben
Pfeil 15.5 Serielle Verarbeitung von XML mit SAX
Pfeil 15.5.1 Schnittstellen von SAX
Pfeil 15.5.2 SAX-Parser erzeugen
Pfeil 15.5.3 Operationen der Schnittstelle ContentHandler
Pfeil 15.5.4 ErrorHandler und EntityResolver
Pfeil 15.6 XML-Dateien mit JDOM verarbeiten
Pfeil 15.6.1 JDOM beziehen
Pfeil 15.6.2 Paketübersicht
Pfeil 15.6.3 Die Document-Klasse
Pfeil 15.6.4 Eingaben aus der Datei lesen
Pfeil 15.6.5 Das Dokument im XML-Format ausgeben
Pfeil 15.6.6 Der Dokumenttyp
Pfeil 15.6.7 Elemente
Pfeil 15.6.8 Zugriff auf Elementinhalte
Pfeil 15.6.9 Liste mit Unterelementen erzeugen
Pfeil 15.6.10 Neue Elemente einfügen und ändern
Pfeil 15.6.11 Attributinhalte lesen und ändern
Pfeil 15.6.12 XPath
Pfeil 15.7 Transformationen mit XSLT
Pfeil 15.7.1 Templates und XPath als Kernelemente von XSLT
Pfeil 15.7.2 Umwandlung von XML-Dateien mit JDOM und JAXP
Pfeil 15.8 Java Architecture for XML Binding (JAXB)
Pfeil 15.8.1 Beans für JAXB aufbauen
Pfeil 15.8.2 JAXBContext und die Marshaller/Unmarshaller
Pfeil 15.8.3 Weitere JAXB-Annotationen
Pfeil 15.9 HTML-Dokumente einlesen
Pfeil 15.10 Zum Weiterlesen


Galileo Computing - Zum Seitenanfang

15.7 Transformationen mit XSLT Zur nächsten ÜberschriftZur vorigen Ü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.


Galileo Computing - Zum Seitenanfang

15.7.1 Templates und XPath als Kernelemente von XSLT Zur nächsten ÜberschriftZur vorigen Ü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 15.27 party.xsl

<?xml version="1.0" encoding="ISO-8859–1"?> 
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<!-- Match auf das Root Element des XPath-Baum --> 
<!-- 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.01</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.


Galileo Computing - Zum Seitenanfang

15.7.2 Umwandlung von XML-Dateien mit JDOM und JAXP topZur vorigen Ü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 15.28 com/tutego/insel/xslt/XslTransformer.java, main()

Document   doc        = new SAXBuilder().build( "party.xml" ); 
Source     xmlFile    = new JDOMSource( doc ); 
JDOMResult htmlResult = new JDOMResult();

Das JDOM-Dokument doc wird ummantelt vom Objekt xmlFile vom Typ JDOMSource, 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 erzeugt ein Objekt der Klasse Transformer. Dieses ist ein Objekt aus dem JAXP-Paket und übernimmt die Umwandlung von XML-Dateien mit Hilfe 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.

Transformer transformer = 
   TransformerFactory.newInstance().newTransformer( 
      new StreamSource("party.xsl") );

Mit dem Transformer-Objekt und einem Source- und Result-Objekt aus JAXP stößt transform() die Übersetzung an:

transformer.transform( xmlFile, htmlResult );

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

Geben wir das Original und das transformierte JDOM-Dokument auf der Konsole aus:

XMLOutputter xmlOutputter = new XMLOutputter(); 
xmlOutputter.output( doc, System.out ); 
xmlOutputter.output( htmlResult.getDocument(), System.out );

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 gewöhnten 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.



Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen.






<< zurück
  Zum Katalog
Zum Katalog: Java ist auch eine Insel





Java ist auch eine Insel
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Tipp
Zum Katalog: Coding for Fun





 Coding for Fun


 Buchempfehlungen
Zum Katalog: Objektorientierte Programmierung





 Objektorientierte
 Programmierung


Zum Katalog: Einstieg in Eclipse 3.4






 Einstieg in
 Eclipse 3.4


Zum Katalog: Java 6 lernen mit Eclipse






 Java 6 lernen
 mit Eclipse


Zum Katalog: NetBeans Platform 6






 NetBeans
 Platform 6


Zum Katalog: Java und XML






 Java und XML


Zum Katalog: Visual C# 2008






 Visual C# 2008


Zum Katalog: IT-Handbuch für Fachinformatiker






 IT-Handbuch für
 Fachinformatiker


Zum Katalog: C++ von A bis Z






 C++ von A bis Z


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Galileo Press 2009
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.


[Galileo Computing]

Galileo Press, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, info@galileo-press.de