-
- All Superinterfaces:
XMLStreamConstants
,XMLStreamReader
public interface XMLStreamReaderEx extends XMLStreamReader
XMLStreamReader
extended for reading binary data.Some producer of infoset (in particular, such as FastInfoset, XOP decoder), uses a native format that enables efficient treatment of binary data. For ordinary infoset consumer (that just uses
XMLStreamReader
, those binary data will just look like base64-encoded string, but this interface allows consumers of such infoset to access this raw binary data. Such infoset producer may choose to implement this additoinal interface, to expose this functionality.Consumers that are capable of using this interface can query
XMLStreamReader
if it supports this by simply downcasting it to this interface like this:XMLStreamReader reader = ...; if( reader instanceof XMLStreamReaderEx ) { // this reader supports binary data exchange ... } else { // noop ... }
Also note that it is also allowed for the infoset producer to implement this interface in such a way that
getPCDATA()
always delegate toXMLStreamReader.getText()
, although it's not desirable.This interface is a private contract between such producers and consumers to allow them to exchange binary data without converting it to base64.
- Author:
- Kohsuke Kawaguchi, Paul Sandoz
- See Also:
XMLStreamWriterEx
-
-
Field Summary
-
Fields inherited from interface javax.xml.stream.XMLStreamConstants
ATTRIBUTE, CDATA, CHARACTERS, COMMENT, DTD, END_DOCUMENT, END_ELEMENT, ENTITY_DECLARATION, ENTITY_REFERENCE, NAMESPACE, NOTATION_DECLARATION, PROCESSING_INSTRUCTION, SPACE, START_DOCUMENT, START_ELEMENT
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description String
getElementTextTrim()
Works likeXMLStreamReader.getElementText()
but trims the leading and trailing whitespace.NamespaceContextEx
getNamespaceContext()
CharSequence
getPCDATA()
Works likeXMLStreamReader.getText()
but hides the actual data representation.-
Methods inherited from interface javax.xml.stream.XMLStreamReader
close, getAttributeCount, getAttributeLocalName, getAttributeName, getAttributeNamespace, getAttributePrefix, getAttributeType, getAttributeValue, getAttributeValue, getCharacterEncodingScheme, getElementText, getEncoding, getEventType, getLocalName, getLocation, getName, getNamespaceCount, getNamespacePrefix, getNamespaceURI, getNamespaceURI, getNamespaceURI, getPIData, getPITarget, getPrefix, getProperty, getText, getTextCharacters, getTextCharacters, getTextLength, getTextStart, getVersion, hasName, hasNext, hasText, isAttributeSpecified, isCharacters, isEndElement, isStandalone, isStartElement, isWhiteSpace, next, nextTag, require, standaloneSet
-
-
-
-
Method Detail
-
getPCDATA
CharSequence getPCDATA() throws XMLStreamException
Works likeXMLStreamReader.getText()
but hides the actual data representation.- Returns:
- The
CharSequence
that represents the character infoset items at the current position.The
CharSequence
is normally aString
, but can be any otherCharSequence
implementation. For binary data, however, use ofBase64Data
is recommended (so that the consumer interested in seeing it as binary data may take advantage of mor efficient data representation.)The object returned from this method belongs to the parser, and its content is guaranteed to be the same only until the
XMLStreamReader.next()
method is invoked. - Throws:
IllegalStateException
- if the parser is not pointing at characters infoset item. TODO: fix the dependency to JAXB internal class.XMLStreamException
-
getNamespaceContext
NamespaceContextEx getNamespaceContext()
- Specified by:
getNamespaceContext
in interfaceXMLStreamReader
-
getElementTextTrim
String getElementTextTrim() throws XMLStreamException
Works likeXMLStreamReader.getElementText()
but trims the leading and trailing whitespace.The parser can often do this more efficiently than
getElementText().trim()
.- Throws:
XMLStreamException
- See Also:
XMLStreamReader.getElementText()
-
-