Class AbstractUnmarshallerImpl
- All Implemented Interfaces:
- Unmarshaller
Unmarshaller implementation.
 
 
 This class provides a partial default implementation for the
 Unmarshallerinterface.
 
 
A Jakarta XML Binding Provider has to implement five methods (getUnmarshallerHandler, unmarshal(Node), unmarshal(XMLReader,InputSource), unmarshal(XMLStreamReader), and unmarshal(XMLEventReader).
- Since:
- 1.6, JAXB 1.0
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from interface jakarta.xml.bind.UnmarshallerUnmarshaller.Listener
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected booleanwhether or not the unmarshaller will validate
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected UnmarshalExceptionCreates an UnmarshalException from a SAXException.<A extends XmlAdapter>
 AgetAdapter(Class<A> type) Gets the adapter associated with the specified type.Return the current event handler or the default event handler if one hasn't been set.ReturnUnmarshaller.Listenerregistered with thisUnmarshaller.getProperty(String name) Default implementation of the getProperty method always throws PropertyException since there are no required properties.Get the JAXP 1.3Schemaobject being used to perform unmarshal-time validation.protected XMLReaderObtains a configured XMLReader.booleanIndicates whether or not the Unmarshaller is configured to validate during unmarshal operations.voidsetAdapter(XmlAdapter adapter) Associates a configured instance ofXmlAdapterwith this unmarshaller.<A extends XmlAdapter>
 voidsetAdapter(Class<A> type, A adapter) Associates a configured instance ofXmlAdapterwith this unmarshaller.voidAssociate a context that resolves cid's, content-id URIs, to binary data passed as attachments.voidsetEventHandler(ValidationEventHandler handler) Allow an application to register a validation event handler.voidsetListener(Unmarshaller.Listener listener) Register unmarshal event callbackUnmarshaller.Listenerwith thisUnmarshaller.voidsetProperty(String name, Object value) Default implementation of the setProperty method always throws PropertyException since there are no required properties.voidSpecify the JAXP 1.3Schemaobject that should be used to validate subsequent unmarshal operations against.voidsetValidating(boolean validating) Specifies whether or not the Unmarshaller should validate during unmarshal operations.final ObjectUnmarshal XML data from the specified file and return the resulting content tree.final Objectunmarshal(InputStream is) Unmarshal XML data from the specified InputStream and return the resulting content tree.final ObjectUnmarshal XML data from the specified Reader and return the resulting content tree.final ObjectUnmarshal XML data from the specified URL and return the resulting content tree.unmarshal(XMLEventReader reader) Unmarshal XML data from the specified pull parser and return the resulting content tree.<T> JAXBElement<T>unmarshal(XMLEventReader reader, Class<T> expectedType) Unmarshal root element to Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.unmarshal(XMLStreamReader reader) Unmarshal XML data from the specified pull parser and return the resulting content tree.<T> JAXBElement<T>unmarshal(XMLStreamReader reader, Class<T> expectedType) Unmarshal root element to Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.Unmarshal XML data from the specified XML Source and return the resulting content tree.<T> JAXBElement<T>Unmarshal XML data from the specified XML Source bydeclaredTypeand return the resulting content tree.<T> JAXBElement<T>Unmarshal XML data by Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.final Objectunmarshal(InputSource source) Unmarshal XML data from the specified SAX InputSource and return the resulting content tree.protected abstract Objectunmarshal(XMLReader reader, InputSource source) Unmarshals an object by using the specified XMLReader and the InputSource.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface jakarta.xml.bind.UnmarshallergetUnmarshallerHandler, unmarshal
- 
Field Details- 
validatingprotected boolean validatingwhether or not the unmarshaller will validate
 
- 
- 
Constructor Details- 
AbstractUnmarshallerImplpublic AbstractUnmarshallerImpl()
 
- 
- 
Method Details- 
getXMLReaderObtains a configured XMLReader. This method is used when the client-specifiedSAXSourceobject doesn't have XMLReader.Unmarshalleris not re-entrant, so we will only use one instance of XMLReader.- Throws:
- JAXBException
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified XML Source and return the resulting content tree.Implements Unmarshal Global Root Element. A client application can choose not to use the default parser mechanism supplied with their Jakarta XML Binding provider. Any SAX 2.0 compliant parser can be substituted for the Jakarta XML Binding provider's default mechanism. To do so, the client application must properly configure a SAXSourcecontaining anXMLReaderimplemented by the SAX 2.0 parser provider. If theXMLReaderhas anorg.xml.sax.ErrorHandlerregistered on it, it will be replaced by the Jakarta XML Binding Provider so that validation errors can be reported via theValidationEventHandlermechanism of Jakarta XML Binding. If theSAXSourcedoes not contain anXMLReader, then the Jakarta XML Binding provider's default parser mechanism will be used.This parser replacement mechanism can also be used to replace the Jakarta XML Binding provider's unmarshal-time validation engine. The client application must properly configure their SAX 2.0 compliant parser to perform validation (as shown in the example above). Any SAXParserExceptionsencountered by the parser during the unmarshal operation will be processed by the Jakarta XML Binding provider and converted into Jakarta XML BindingValidationEventobjects which will be reported back to the client via theValidationEventHandlerregistered with theUnmarshaller. Note: specifying a substitute validating SAX 2.0 parser for unmarshalling does not necessarily replace the validation engine used by the Jakarta XML Binding provider for performing on-demand validation.The only way for a client application to specify an alternate parser mechanism to be used during unmarshal is via the unmarshal(SAXSource)API. All other forms of the unmarshal method (File, URL, Node, etc) will use the Jakarta XML Binding provider's default parser and validator mechanisms.- Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- source- the XML Source to unmarshal XML data from (providers are only required to support SAXSource, DOMSource, and StreamSource)
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
- See Also:
 
- 
unmarshalUnmarshals an object by using the specified XMLReader and the InputSource. The callee should call the setErrorHandler method of the XMLReader so that errors are passed to the client-specified ValidationEventHandler.- Throws:
- JAXBException
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified SAX InputSource and return the resulting content tree.Implements Unmarshal Global Root Element. - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- source- the input source to unmarshal XML data from
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified URL and return the resulting content tree.Implements Unmarshal Global Root Element. - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- url- the url to unmarshal XML data from
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified file and return the resulting content tree.Implements Unmarshal Global Root Element. - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- f- the file to unmarshal XML data from
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified InputStream and return the resulting content tree. Validation event location information may be incomplete when using this form of the unmarshal API.Implements Unmarshal Global Root Element. - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- is- the InputStream to unmarshal XML data from
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified Reader and return the resulting content tree. Validation event location information may be incomplete when using this form of the unmarshal API, because a Reader does not provide the system ID.Implements Unmarshal Global Root Element. - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- reader- the Reader to unmarshal XML data from
- Returns:
- the newly created root object of the java content tree
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
isValidatingIndicates whether or not the Unmarshaller is configured to validate during unmarshal operations.Note: I named this method isValidating() to stay in-line with JAXP, as opposed to naming it getValidating(). - Specified by:
- isValidatingin interface- Unmarshaller
- Returns:
- true if the Unmarshaller is configured to validate during unmarshal operations, false otherwise
- Throws:
- JAXBException- if an error occurs while retrieving the validating flag
 
- 
setEventHandlerAllow an application to register a validation event handler.The validation event handler will be called by the Jakarta XML Binding Provider if any validation errors are encountered during calls to any of the unmarshalmethods. If the client application does not register a validation event handler before invoking the unmarshal methods, then all validation events will be silently ignored and may result in unexpected behaviour.- Specified by:
- setEventHandlerin interface- Unmarshaller
- Parameters:
- handler- the validation event handler
- Throws:
- JAXBException- if an error was encountered while setting the event handler
 
- 
setValidatingSpecifies whether or not the Unmarshaller should validate during unmarshal operations. By default, theUnmarshallerdoes not validate.This method may only be invoked before or after calling one of the unmarshal methods. - Specified by:
- setValidatingin interface- Unmarshaller
- Parameters:
- validating- true if the Unmarshaller should validate during unmarshal, false otherwise
- Throws:
- JAXBException- if an error occurred while enabling or disabling validation at unmarshal time
 
- 
getEventHandlerReturn the current event handler or the default event handler if one hasn't been set.- Specified by:
- getEventHandlerin interface- Unmarshaller
- Returns:
- the current ValidationEventHandler or the default event handler if it hasn't been set
- Throws:
- JAXBException- if an error was encountered while getting the current event handler
 
- 
createUnmarshalExceptionCreates an UnmarshalException from a SAXException. This is an utility method provided for the derived classes.When a provider-implemented ContentHandler wants to throw a JAXBException, it needs to wrap the exception by a SAXException. If the unmarshaller implementation blindly wrap SAXException by JAXBException, such an exception will be a JAXBException wrapped by a SAXException wrapped by another JAXBException. This is silly. This method checks the nested exception of SAXException and reduce those excessive wrapping. - Returns:
- the resulting UnmarshalException
 
- 
setPropertyDefault implementation of the setProperty method always throws PropertyException since there are no required properties. If a provider needs to handle additional properties, it should override this method in a derived class.- Specified by:
- setPropertyin interface- Unmarshaller
- Parameters:
- name- the name of the property to be set. This value can either be specified using one of the constant fields or a user supplied string.
- value- the value of the property to be set
- Throws:
- PropertyException- when there is an error processing the given property or value
 
- 
getPropertyDefault implementation of the getProperty method always throws PropertyException since there are no required properties. If a provider needs to handle additional properties, it should override this method in a derived class.- Specified by:
- getPropertyin interface- Unmarshaller
- Parameters:
- name- the name of the property to retrieve
- Returns:
- the value of the requested property
- Throws:
- PropertyException- when there is an error retrieving the given property or value property name
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified pull parser and return the resulting content tree.This method is an Unmarshal Global Root method. This method assumes that the parser is on a START_DOCUMENT or START_ELEMENT event. Unmarshalling will be done from this start event to the corresponding end event. If this method returns successfully, the readerwill be pointing at the token right after the end event.- Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- reader- The parser to be read.
- Returns:
- the newly created root object of the java content tree.
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
- See Also:
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified pull parser and return the resulting content tree.Implements Unmarshal Global Root Element. This method assumes that the parser is on a START_DOCUMENT or START_ELEMENT event. Unmarshalling will be done from this start event to the corresponding end event. If this method returns successfully, the readerwill be pointing at the token right after the end event.- Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- reader- The parser to be read.
- Returns:
- the newly created root object of the java content tree.
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
- See Also:
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data by Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.Implements Unmarshal by Declared Type - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- node- the document/element to unmarshal XML data from. The caller must support at least Document and Element.
- expectedType- appropriate Jakarta XML Binding mapped class to hold- node's XML data.
- Returns:
- JAXBElement representation of node
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalDescription copied from interface:UnmarshallerUnmarshal XML data from the specified XML Source bydeclaredTypeand return the resulting content tree.Implements Unmarshal by Declared Type - Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- source- the XML Source to unmarshal XML data from (providers are only required to support SAXSource, DOMSource, and StreamSource)
- expectedType- appropriate Jakarta XML Binding mapped class to hold- source's xml root element
- Returns:
- Java content rooted by JAXBElement
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalpublic <T> JAXBElement<T> unmarshal(XMLStreamReader reader, Class<T> expectedType) throws JAXBException Description copied from interface:UnmarshallerUnmarshal root element to Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.This method implements unmarshal by declaredType. This method assumes that the parser is on a START_DOCUMENT or START_ELEMENT event. Unmarshalling will be done from this start event to the corresponding end event. If this method returns successfully, the readerwill be pointing at the token right after the end event.- Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- reader- The parser to be read.
- expectedType- appropriate Jakarta XML Binding mapped class to hold- reader's START_ELEMENT XML data.
- Returns:
- content tree rooted by JAXBElement representation
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
unmarshalpublic <T> JAXBElement<T> unmarshal(XMLEventReader reader, Class<T> expectedType) throws JAXBException Description copied from interface:UnmarshallerUnmarshal root element to Jakarta XML Binding mappeddeclaredTypeand return the resulting content tree.This method implements unmarshal by declaredType. This method assumes that the parser is on a START_DOCUMENT or START_ELEMENT event. Unmarshalling will be done from this start event to the corresponding end event. If this method returns successfully, the readerwill be pointing at the token right after the end event.- Specified by:
- unmarshalin interface- Unmarshaller
- Parameters:
- reader- The parser to be read.
- expectedType- appropriate Jakarta XML Binding mapped class to hold- reader's START_ELEMENT XML data.
- Returns:
- content tree rooted by JAXBElement representation
- Throws:
- JAXBException- If any unexpected errors occur while unmarshalling
- UnmarshalException- If the- ValidationEventHandlerreturns false from its- handleEventmethod or the- Unmarshalleris unable to perform the XML to Java binding. See Unmarshalling XML Data
 
- 
setSchemaDescription copied from interface:UnmarshallerSpecify the JAXP 1.3Schemaobject that should be used to validate subsequent unmarshal operations against. Passing null into this method will disable validation.This method replaces the deprecated setValidating(boolean)API.Initially this property is set to null.- Specified by:
- setSchemain interface- Unmarshaller
- Parameters:
- schema- Schema object to validate unmarshal operations against or null to disable validation
 
- 
getSchemaDescription copied from interface:UnmarshallerGet the JAXP 1.3Schemaobject being used to perform unmarshal-time validation. If there is no Schema set on the unmarshaller, then this method will return null indicating that unmarshal-time validation will not be performed.This method provides replacement functionality for the deprecated Unmarshaller.isValidating()API as well as access to the Schema object. To determine if the Unmarshaller has validation enabled, simply test the return type for null:boolean isValidating = u.getSchema()!=null;- Specified by:
- getSchemain interface- Unmarshaller
- Returns:
- the Schema object being used to perform unmarshal-time validation or null if not present
 
- 
setAdapterDescription copied from interface:UnmarshallerAssociates a configured instance ofXmlAdapterwith this unmarshaller.This is a convenience method that invokes setAdapter(adapter.getClass(),adapter);.- Specified by:
- setAdapterin interface- Unmarshaller
- See Also:
 
- 
setAdapterDescription copied from interface:UnmarshallerAssociates a configured instance ofXmlAdapterwith this unmarshaller.Every unmarshaller internally maintains a Map<Class,XmlAdapter>, which it uses for unmarshalling classes whose fields/methods are annotated withXmlJavaTypeAdapter.This method allows applications to use a configured instance of XmlAdapter. When an instance of an adapter is not given, an unmarshaller will create one by invoking its default constructor.- Specified by:
- setAdapterin interface- Unmarshaller
- Parameters:
- type- The type of the adapter. The specified instance will be used when- XmlJavaTypeAdapter.value()refers to this type.
- adapter- The instance of the adapter to be used. If null, it will un-register the current adapter set for this type.
 
- 
getAdapterDescription copied from interface:UnmarshallerGets the adapter associated with the specified type. This is the reverse operation of theUnmarshaller.setAdapter(jakarta.xml.bind.annotation.adapters.XmlAdapter)method.- Specified by:
- getAdapterin interface- Unmarshaller
 
- 
setAttachmentUnmarshallerDescription copied from interface:UnmarshallerAssociate a context that resolves cid's, content-id URIs, to binary data passed as attachments. Unmarshal time validation, enabled via Unmarshaller.setSchema(Schema), must be supported even when unmarshaller is performing XOP processing.- Specified by:
- setAttachmentUnmarshallerin interface- Unmarshaller
 
- 
getAttachmentUnmarshaller- Specified by:
- getAttachmentUnmarshallerin interface- Unmarshaller
 
- 
setListenerDescription copied from interface:UnmarshallerRegister unmarshal event callback Unmarshaller.Listenerwith thisUnmarshaller.There is only one Listener per Unmarshaller. Setting a Listener replaces the previous set Listener. One can unregister current Listener by setting listener to null.- Specified by:
- setListenerin interface- Unmarshaller
- Parameters:
- listener- provides unmarshal event callbacks for this- Unmarshaller
 
- 
getListenerDescription copied from interface:UnmarshallerReturn Unmarshaller.Listenerregistered with thisUnmarshaller.- Specified by:
- getListenerin interface- Unmarshaller
- Returns:
- registered Unmarshaller.Listenerornullif no Listener is registered with this Unmarshaller.
 
 
-