Class MappingLdifReader<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.ldif.MappingLdifReader<T>
- All Implemented Interfaces:
- ResourceAwareItemReaderItemStream<T>,- ItemReader<T>,- ItemStream,- ItemStreamReader<T>,- org.springframework.beans.factory.InitializingBean
public class MappingLdifReader<T>
extends AbstractItemCountingItemStreamItemReader<T>
implements ResourceAwareItemReaderItemStream<T>, org.springframework.beans.factory.InitializingBean
The 
MappingLdifReader is an adaptation of the FlatFileItemReader
 built around an LdifParser.  It differs from the standard LdifReader in its ability to map
 LdapAttributes objects to POJOs.
 
 The MappingLdifReader requires an RecordMapper implementation. If mapping
 is not required, the LdifReader should be used instead. It simply returns an LdapAttributes
 object which can be consumed and manipulated as necessary by ItemProcessor or any
 output service.
 
 As with the FlatFileItemReader, the strict option
 differentiates between whether or not to require the resource to exist before processing.  In the case of a value set to false, a warning
 is logged instead of an exception being thrown.
- Author:
- Keith Barlow
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidprotected voiddoClose()Close the resources opened inAbstractItemCountingItemStreamItemReader.doOpen().protected voiddoOpen()Open resources necessary to start reading input.protected TdoRead()Read next item from input.voidsetRecordMapper(RecordMapper<T> recordMapper) Setter for object mapper.voidsetRecordsToSkip(int recordsToSkip) Public setter for the number of lines to skip at the start of a file.voidsetResource(org.springframework.core.io.Resource resource) voidsetSkippedRecordsCallback(RecordCallbackHandler skippedRecordsCallback) RecordCallbackHandlerimplementations can be used to take action on skipped records.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.Methods inherited from class org.springframework.batch.item.support.AbstractItemCountingItemStreamItemReaderclose, getCurrentItemCount, isSaveState, jumpToItem, open, read, setCurrentItemCount, setMaxItemCount, setSaveState, updateMethods inherited from class org.springframework.batch.item.ItemStreamSupportgetExecutionContextKey, 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
- 
Constructor Details- 
MappingLdifReaderpublic MappingLdifReader()
 
- 
- 
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- false by default
 
- 
setSkippedRecordsCallbackRecordCallbackHandlerimplementations can be used to take action on skipped records.- Parameters:
- skippedRecordsCallback- will be called for each one of the initial skipped lines before any items are read.
 
- 
setRecordsToSkippublic void setRecordsToSkip(int recordsToSkip) Public setter for the number of lines to skip at the start of a file. Can be used if the file contains a header without useful (column name) information, and without a comment delimiter at the beginning of the lines.- Parameters:
- recordsToSkip- the number of lines to skip
 
- 
setRecordMapperSetter for object mapper. This property is required to be set.- Parameters:
- recordMapper- maps record to an object
 
- 
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
 
- 
doReadDescription copied from class:AbstractItemCountingItemStreamItemReaderRead next item from input.- Specified by:
- doReadin class- AbstractItemCountingItemStreamItemReader<T>
- Returns:
- an item or nullif the data source is exhausted
- Throws:
- Exception- Allows subclasses to throw checked exceptions for interpretation by the framework
 
- 
setResourcepublic void setResource(org.springframework.core.io.Resource resource) - Specified by:
- setResourcein interface- ResourceAwareItemReaderItemStream<T>
 
- 
afterPropertiesSet- Specified by:
- afterPropertiesSetin interface- org.springframework.beans.factory.InitializingBean
- Throws:
- Exception
 
 
-