Rheinwerk Computing < openbook > Rheinwerk 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 Eigene Klassen schreiben
6 Exceptions
7 Generics<T>
8 Äußere.innere Klassen
9 Besondere Klassen der Java SE
10 Architektur, Design und angewandte Objektorientierung
11 Die Klassenbibliothek
12 Bits und Bytes und Mathematisches
13 Datenstrukturen und Algorithmen
14 Threads und nebenläufige Programmierung
15 Raum und Zeit
16 Dateien, Verzeichnisse und Dateizugriffe
17 Datenströme
18 Die eXtensible Markup Language (XML)
19 Grafische Oberflächen mit Swing
20 Grafikprogrammierung
21 Netzwerkprogrammierung
22 Verteilte Programmierung mit RMI
23 JavaServer Pages und Servlets
24 Datenbankmanagement mit JDBC
25 Reflection und Annotationen
26 Dienstprogramme für die Java-Umgebung
A Die Begleit-DVD
Stichwort
Ihre Meinung?

Spacer
 <<   zurück
Java ist auch eine Insel von Christian Ullenboom
Das umfassende Handbuch
Buch: Java ist auch eine Insel

Java ist auch eine Insel
geb., mit DVD
1482 S., 49,90 Euro
Rheinwerk Computing
ISBN 978-3-8362-1506-0
Pfeil 18 Die eXtensible Markup Language (XML)
  Pfeil 18.1 Auszeichnungssprachen
    Pfeil 18.1.1 Die Standard Generalized Markup Language (SGML)
    Pfeil 18.1.2 Extensible Markup Language (XML)
  Pfeil 18.2 Eigenschaften von XML-Dokumenten
    Pfeil 18.2.1 Elemente und Attribute
    Pfeil 18.2.2 Beschreibungssprache für den Aufbau von XML-Dokumenten
    Pfeil 18.2.3 Schema – eine Alternative zu DTD
    Pfeil 18.2.4 Namensraum (Namespace)
    Pfeil 18.2.5 XML-Applikationen *
  Pfeil 18.3 Die Java-APIs für XML
    Pfeil 18.3.1 Das Document Object Model (DOM)
    Pfeil 18.3.2 Simple API for XML Parsing (SAX)
    Pfeil 18.3.3 Pull-API StAX
    Pfeil 18.3.4 Java Document Object Model (JDOM)
    Pfeil 18.3.5 JAXP als Java-Schnittstelle zu XML
    Pfeil 18.3.6 DOM-Bäume einlesen mit JAXP *
  Pfeil 18.4 Java Architecture for XML Binding (JAXB)
    Pfeil 18.4.1 Bean für JAXB aufbauen
    Pfeil 18.4.2 JAXBContext und die Marshaller
    Pfeil 18.4.3 Ganze Objektgraphen schreiben und lesen
    Pfeil 18.4.4 Validierung
    Pfeil 18.4.5 Weitere JAXB-Annotationen *
    Pfeil 18.4.6 Beans aus XML-Schema-Datei generieren
  Pfeil 18.5 Serielle Verarbeitung mit StAX
    Pfeil 18.5.1 Unterschiede der Verarbeitungsmodelle
    Pfeil 18.5.2 XML-Dateien mit dem Cursor-Verfahren lesen
    Pfeil 18.5.3 XML-Dateien mit dem Iterator-Verfahren verarbeiten *
    Pfeil 18.5.4 Mit Filtern arbeiten *
    Pfeil 18.5.5 XML-Dokumente schreiben
  Pfeil 18.6 Serielle Verarbeitung von XML mit SAX *
    Pfeil 18.6.1 Schnittstellen von SAX
    Pfeil 18.6.2 SAX-Parser erzeugen
    Pfeil 18.6.3 Operationen der Schnittstelle »ContentHandler«
    Pfeil 18.6.4 ErrorHandler und EntityResolver
  Pfeil 18.7 XML-Dateien mit JDOM verarbeiten
    Pfeil 18.7.1 JDOM beziehen
    Pfeil 18.7.2 Paketübersicht *
    Pfeil 18.7.3 Die Document-Klasse
    Pfeil 18.7.4 Eingaben aus der Datei lesen
    Pfeil 18.7.5 Das Dokument im XML-Format ausgeben
    Pfeil 18.7.6 Der Dokumenttyp *
    Pfeil 18.7.7 Elemente
    Pfeil 18.7.8 Zugriff auf Elementinhalte
    Pfeil 18.7.9 Liste mit Unterelementen erzeugen *
    Pfeil 18.7.10 Neue Elemente einfügen und ändern
    Pfeil 18.7.11 Attributinhalte lesen und ändern
    Pfeil 18.7.12 XPath
  Pfeil 18.8 Transformationen mit XSLT *
    Pfeil 18.8.1 Templates und XPath als Kernelemente von XSLT
    Pfeil 18.8.2 Umwandlung von XML-Dateien mit JDOM und JAXP
  Pfeil 18.9 XML-Schema-Validierung *
    Pfeil 18.9.1 SchemaFactory und Schema
    Pfeil 18.9.2 Validator
    Pfeil 18.9.3 Validierung unterschiedlicher Datenquellen durchführen
  Pfeil 18.10 Zum Weiterlesen


Rheinwerk Computing - Zum Seitenanfang

18.9 XML-Schema-Validierung *  Zur nächsten ÜberschriftZur vorigen Überschrift

XML ist ein sehr freies Format und Dokumente können leicht XML-Elemente enthalten, die so eigentlich vom Designer nicht vorgesehen waren. Um sicherzustellen, dass XML-Dokumente nicht zu »frei« sind, sondern sich an bestimmte Regeln halten, gib es unterschiedliche Korrektheitsbeschreibungen. Die populärste ist XML Schema (siehe auch Abschnitt 18.2.3, »Schema – eine Alternative zu DTD«), die das ältere DTD ersetzt hat. Eine XML-Schema-Datei hat ebenfalls das XML-Format (anders als DTD) und wird einem Parser zusammen mit der XML-Datei gegeben. Der liest ein XML-Dokument ein und prüft, ob die Regeln eingehalten werden.


Rheinwerk Computing - Zum Seitenanfang

18.9.1 SchemaFactory und Schema  Zur nächsten ÜberschriftZur vorigen Überschrift

Java unterstützt die Schema-Validierung, die jedoch standardmäßig ausgeschaltet ist. Ein Grund ist, dass die Validierung die Rechenzeit und den Speicherbedarf erhöht. Um die Validierung zu aktivieren, muss zunächst ein Schema-Objekt aufgebaut werden. Bei JAXB haben wir die Validierung schon genutzt und Folgendes geschrieben:

SchemaFactory sf = SchemaFactory.newInstance( XMLConstants.W3C_XML_SCHEMA_NS_URI );
Schema schema = sf.newSchema( ValidatingRoomUnmarshaller.class.getResource( Umbruch
  "/schema1.xsd" ) );

Das Objekt vom Typ Schema repräsentiert die Schema-Beschreibung.


Rheinwerk Computing - Zum Seitenanfang

18.9.2 Validator  Zur nächsten ÜberschriftZur vorigen Überschrift

Im Fall von JAXB wurde das Schema-Objekt direkt an JAXB festgemacht und zur Validierung genutzt. Unabhängig davon bietet das Schema-Objekt die zentrale Methode newValidator(), die einen Validator liefert, der letztlich die Validierung durchführt.

Schema schema = ...
Validator validator = schema.newValidator();

abstract class javax.xml.validation.SchemaFactory

  • final SchemaFactory newInstance( String schemaLanguage ) Liefert eine SchemaFactory, die die angegebene Schema-Sprache unterstützt. Bei der XML-Schema-Validierung wird der String immer XMLConstants.W3C_XML_SCHEMA_NS_URI sein, also "http://www.w3.org/2001/XMLSchema". Es gibt zwar auch die Konstante RELAXNG_NS_URI für RELAX NG Schema-Validierung, doch JAXP unterstützt dies nicht.
  • Schema newSchema( File schema ) throws SAXException Parst die Datei und baut das Schema-Objekt aus. Gibt es beim Parsen Fehler, folgt die SAXException.
  • Schema newSchema( URL schema ) throws SAXException Holt sich die Schema-Datei von der URL, parst sie und baut das Schema-Objekt auf. Gibt es beim Parsen Fehler, folgt die SAXException.

abstract class javax.xml.validation.Schema

  • abstract Validator newValidator() Liefert einen Validator für das Schema.

Rheinwerk Computing - Zum Seitenanfang

18.9.3 Validierung unterschiedlicher Datenquellen durchführen  topZur vorigen Überschrift

Dieser Validator bietet die Methode validate() und ihr übergeben wird entweder eine DOMSource, JAXBSource, SAXSource, StAXSource, StreamSource, also ganz allgemein gesprochen ein Objekt vom Typ javax.xml.transform.Source. An dem Paket lässt sich ablesen, dass Source ein Typ aus dem XSLT-Paket ist.

Wie ist nun der Weg, um etwa einen DOM-Baum zu validieren? Der DOM-Baum muss als Source-Objekt verpackt werden und dann der validate()-Methode übergeben werden. Etwa so:

Document document = …
validator.validate( new DOMSource(document) );

Gibt es Fehler, gibt es eine SAXException, die eine geprüfte Ausnahme ist, also behandelt werden muss. Es lässt sich mit setErrorHandler() ein spezieller ErrorHandler setzen, damit Fehler dort aufgefangen und dokumentiert werden können.


abstract class javax.xml.validation.Validator

  • void validate( Source source ) throws SAXException, IOException Führt die Validierung der Eingabe durch.
  • abstract void setErrorHandler( ErrorHandler errorHandler ) Setzt ein Objekt zum Auffangen der Fehler.


Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen. >> Zum Feedback-Formular
 <<   zurück
 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Buchempfehlungen
Zum Katalog: Java ist auch eine Insel






 Java ist auch
 eine Insel


Zum Katalog: Java SE Bibliotheken






 Java SE Bibliotheken


Zum Katalog: Professionell entwickeln mit Java EE 7






 Professionell
 entwickeln mit
 Java EE 7


Zum Katalog: Einstieg in Eclipse






 Einstieg in
 Eclipse


Zum Katalog: Einstieg in Java






 Einstieg in
 Java


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Rheinwerk Verlag GmbH 2011
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