Class JAXBSource

java.lang.Object
javax.xml.transform.sax.SAXSource
jakarta.xml.bind.util.JAXBSource
All Implemented Interfaces:
Source

public class JAXBSource extends SAXSource
JAXP Source implementation that marshals a Jakarta XML Binding-generated object.

This utility class is useful to combine Jakarta XML Binding with other Java/XML technologies.

The following example shows how to use Jakarta XML Binding to marshal a document for transformation by XSLT.

       MyObject o = // get JAXB content tree

       // jaxbContext is a JAXBContext object from which 'o' is created.
       JAXBSource source = new JAXBSource( jaxbContext, o );

       // set up XSLT transformation
       TransformerFactory tf = TransformerFactory.newInstance();
       Transformer t = tf.newTransformer(new StreamSource("test.xsl"));

       // run transformation
       t.transform(source,new StreamResult(System.out));
    

The fact that JAXBSource derives from SAXSource is an implementation detail. Thus in general applications are strongly discouraged from accessing methods defined on SAXSource. In particular, the setXMLReader and setInputSource methods shall never be called. The XMLReader object obtained by the getXMLReader method shall be used only for parsing the InputSource object returned by the getInputSource method.

Similarly the InputSource object obtained by the getInputSource method shall be used only for being parsed by the XMLReader object returned by the getXMLReader.

Since:
1.6