Class StaxEventItemReader<T>
java.lang.Object
org.springframework.batch.item.ItemStreamSupport
org.springframework.batch.item.support.AbstractItemStreamItemReader<T>
org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReader<T>
org.springframework.batch.item.xml.StaxEventItemReader<T>
- All Implemented Interfaces:
- ResourceAwareItemReaderItemStream<T>,- ItemReader<T>,- ItemStream,- ItemStreamReader<T>,- org.springframework.beans.factory.InitializingBean
public class StaxEventItemReader<T>
extends AbstractItemCountingItemStreamItemReader<T>
implements ResourceAwareItemReaderItemStream<T>, org.springframework.beans.factory.InitializingBean
Item reader for reading XML input based on StAX.
 
It extracts fragments from the input XML document which correspond to records for processing. The fragments are wrapped with StartDocument and EndDocument events so that the fragments can be further processed like standalone XML documents.
The implementation is not thread-safe.
- Author:
- Robert Kasanicky, Mahmoud Ben Hassine
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidEnsure that all required dependencies for the ItemReader to run are provided after all properties have been set.protected voiddoClose()Close the resources opened inAbstractItemCountingItemStreamItemReader.doOpen().protected voiddoOpen()Open resources necessary to start reading input.protected TdoRead()Move to next fragment and map it to item.protected booleanprotected voidjumpToItem(int itemIndex) Move to the given item index.protected booleanResponsible for moving the cursor before the StartElement of the fragment root.voidsetEncoding(String encoding) Set encoding to be used for the input file.voidsetFragmentRootElementName(String fragmentRootElementName) voidsetFragmentRootElementNames(String[] fragmentRootElementNames) voidsetResource(org.springframework.core.io.Resource resource) voidsetStrict(boolean strict) In strict mode the reader will throw an exception onAbstractItemCountingItemStreamItemReader.open(org.springframework.batch.item.ExecutionContext)if the input resource does not exist.voidsetUnmarshaller(org.springframework.oxm.Unmarshaller unmarshaller) voidsetXmlInputFactory(XMLInputFactory xmlInputFactory) Set theXMLInputFactory.Methods inherited from class org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReaderclose, getCurrentItemCount, isSaveState, open, read, setCurrentItemCount, setMaxItemCount, setSaveState, updateMethods inherited from class org.springframework.batch.item.ItemStreamSupportgetExecutionContextKey, getName, setExecutionContextName, setNameMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.batch.item.ItemReaderreadMethods inherited from interface org.springframework.batch.item.ItemStreamclose, open, update
- 
Field Details- 
DEFAULT_ENCODING
 
- 
- 
Constructor Details- 
StaxEventItemReaderpublic StaxEventItemReader()
 
- 
- 
Method Details- 
setStrictpublic void setStrict(boolean strict) In strict mode the reader will throw an exception onAbstractItemCountingItemStreamItemReader.open(org.springframework.batch.item.ExecutionContext)if the input resource does not exist.- Parameters:
- strict- true by default
 
- 
setResourcepublic void setResource(org.springframework.core.io.Resource resource) - Specified by:
- setResourcein interface- ResourceAwareItemReaderItemStream<T>
 
- 
setUnmarshallerpublic void setUnmarshaller(org.springframework.oxm.Unmarshaller unmarshaller) - Parameters:
- unmarshaller- maps xml fragments corresponding to records to objects
 
- 
setFragmentRootElementName- Parameters:
- fragmentRootElementName- name of the root element of the fragment
 
- 
setFragmentRootElementNames- Parameters:
- fragmentRootElementNames- list of the names of the root element of the fragment
 
- 
setXmlInputFactorySet theXMLInputFactory.- Parameters:
- xmlInputFactory- to use
 
- 
setEncodingSet encoding to be used for the input file. Defaults toDEFAULT_ENCODING.- Parameters:
- encoding- the encoding to be used. Can be- null, in which case, the XML event reader will attempt to auto-detect the encoding from tht input file.
 
- 
afterPropertiesSetEnsure that all required dependencies for the ItemReader to run are provided after all properties have been set.- Specified by:
- afterPropertiesSetin interface- org.springframework.beans.factory.InitializingBean
- Throws:
- IllegalArgumentException- if the Resource, FragmentDeserializer or FragmentRootElementName is null, or if the root element is empty.
- IllegalStateException- if the Resource does not exist.
- Exception
- See Also:
- 
- InitializingBean.afterPropertiesSet()
 
 
- 
moveCursorToNextFragmentprotected boolean moveCursorToNextFragment(XMLEventReader reader) throws NonTransientResourceException Responsible for moving the cursor before the StartElement of the fragment root.This implementation simply looks for the next corresponding element, it does not care about element nesting. You will need to override this method to correctly handle composite fragments. - Parameters:
- reader- the- XMLEventReaderto be used to find next fragment.
- Returns:
- trueif next fragment was found,- falseotherwise.
- Throws:
- NonTransientResourceException- if the cursor could not be moved. This will be treated as fatal and subsequent calls to read will return null.
 
- 
doCloseDescription copied from class:AbstractItemCountingItemStreamItemReaderClose the resources opened inAbstractItemCountingItemStreamItemReader.doOpen().- Specified by:
- doClosein class- AbstractItemCountingItemStreamItemReader<T>
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
doOpenDescription copied from class:AbstractItemCountingItemStreamItemReaderOpen resources necessary to start reading input.- Specified by:
- doOpenin class- AbstractItemCountingItemStreamItemReader<T>
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
doReadMove to next fragment and map it to item.- Specified by:
- doReadin class- AbstractItemCountingItemStreamItemReader<T>
- Returns:
- an item or nullif the data source is exhausted
- Throws:
- IOException
- XMLStreamException
 
- 
jumpToItemDescription copied from class:AbstractItemCountingItemStreamItemReaderMove to the given item index. Subclasses should override this method if there is a more efficient way of moving to given index than re-reading the input usingAbstractItemCountingItemStreamItemReader.doRead().- Overrides:
- jumpToItemin class- AbstractItemCountingItemStreamItemReader<T>
- Parameters:
- itemIndex- index of item (0 based) to jump to.
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
isFragmentRootElementName
 
-