Class ByteArrayLengthHeaderSerializer
java.lang.Object
org.springframework.integration.ip.tcp.serializer.AbstractByteArraySerializer
org.springframework.integration.ip.tcp.serializer.ByteArrayLengthHeaderSerializer
- All Implemented Interfaces:
- Aware,- ApplicationEventPublisherAware,- Deserializer<byte[]>,- Serializer<byte[]>
Reads data in an InputStream to a byte[]; data must be preceded by
 a binary length (network byte order, not included in resulting byte[]).
 Writes a byte[] to an OutputStream after a binary length.
 The length field contains the length of data following the length
 field. (network byte order).
 The default length field is a 4 byte signed integer. During deserialization,
 negative values will be rejected.
 Other options are an unsigned byte, and unsigned short.
 For other header formats, override 
readHeader(InputStream) and
 writeHeader(OutputStream, int).- Since:
- 2.0
- Author:
- Gary Russell, Artem Bilan
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intDefault length-header field, allows for data up to 2**31-1 bytes.static final intA single unsigned byte, for data up to 255 bytes.static final intAn unsigned short, for data up to 2**16 bytes.Fields inherited from class org.springframework.integration.ip.tcp.serializer.AbstractByteArraySerializerDEFAULT_MAX_MESSAGE_SIZE, logger
- 
Constructor SummaryConstructorsConstructorDescriptionConstruct the serializer usingHEADER_SIZE_INT.ByteArrayLengthHeaderSerializer(int headerSize) Construct the serializer using the supplied header size.
- 
Method SummaryModifier and TypeMethodDescriptionbyte[]deserialize(InputStream inputStream) Read the header from the stream and then reads the provided length from the stream and returns the data in a byte[].Include the length of the header in addition to the payload.protected booleanReturn true if the length header value includes its own length.protected intread(InputStream inputStream, byte[] buffer, boolean header) Read data from the socket and puts the data in buffer.protected intreadHeader(InputStream inputStream) Read the header and returns the length of the data part.voidserialize(byte[] bytes, OutputStream outputStream) Write the byte[] to the output stream, preceded by a 4 byte length in network byte order (big endian).voidsetInclusive(boolean inclusive) Set to true to set the length header to include the length of the header in addition to the payload.protected voidwriteHeader(OutputStream outputStream, int length) Write the header, according to the header format.Methods inherited from class org.springframework.integration.ip.tcp.serializer.AbstractByteArraySerializercheckClosure, getMaxMessageSize, publishEvent, setApplicationEventPublisher, setMaxMessageSizeMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.core.serializer.DeserializerdeserializeFromByteArrayMethods inherited from interface org.springframework.core.serializer.SerializerserializeToByteArray
- 
Field Details- 
HEADER_SIZE_INTpublic static final int HEADER_SIZE_INTDefault length-header field, allows for data up to 2**31-1 bytes.- See Also:
 
- 
HEADER_SIZE_UNSIGNED_SHORTpublic static final int HEADER_SIZE_UNSIGNED_SHORTAn unsigned short, for data up to 2**16 bytes.- See Also:
 
- 
HEADER_SIZE_UNSIGNED_BYTEpublic static final int HEADER_SIZE_UNSIGNED_BYTEA single unsigned byte, for data up to 255 bytes.- See Also:
 
 
- 
- 
Constructor Details- 
ByteArrayLengthHeaderSerializerpublic ByteArrayLengthHeaderSerializer()Construct the serializer usingHEADER_SIZE_INT.
- 
ByteArrayLengthHeaderSerializerpublic ByteArrayLengthHeaderSerializer(int headerSize) Construct the serializer using the supplied header size. Valid header sizes areHEADER_SIZE_INT(default),HEADER_SIZE_UNSIGNED_BYTEandHEADER_SIZE_UNSIGNED_SHORT- Parameters:
- headerSize- The header size.
 
 
- 
- 
Method Details- 
isInclusiveprotected boolean isInclusive()Return true if the length header value includes its own length.- Returns:
- true if the length includes the header length.
- Since:
- 5.2
 
- 
setInclusivepublic void setInclusive(boolean inclusive) Set to true to set the length header to include the length of the header in addition to the payload. Valid header sizes areHEADER_SIZE_INT(default),HEADER_SIZE_UNSIGNED_BYTEandHEADER_SIZE_UNSIGNED_SHORTand 4, 1 and 2 will be added to the payload length respectively.- Parameters:
- inclusive- true to include the header length.
- Since:
- 5.2
- See Also:
 
- 
inclusiveInclude the length of the header in addition to the payload. Valid header sizes areHEADER_SIZE_INT(default),HEADER_SIZE_UNSIGNED_BYTEandHEADER_SIZE_UNSIGNED_SHORTand 4, 1 and 2 will be added to the payload length respectively. Fluent API form ofsetInclusive(boolean).- Returns:
- the serializer.
- Since:
- 5.2
- See Also:
 
- 
deserializeRead the header from the stream and then reads the provided length from the stream and returns the data in a byte[]. Throws an IOException if the length field exceeds the maxMessageSize. Throws aSoftEndOfStreamExceptionif the stream is closed between messages.- Parameters:
- inputStream- The input stream.
- Throws:
- IOException- Any IOException.
 
- 
serializeWrite the byte[] to the output stream, preceded by a 4 byte length in network byte order (big endian).- Parameters:
- bytes- The bytes.
- outputStream- The output stream.
- Throws:
- IOException
 
- 
readRead data from the socket and puts the data in buffer. Blocks until buffer is full or a socket timeout occurs.- Parameters:
- inputStream- The input stream.
- buffer- the buffer into which the data should be read
- header- true if we are reading the header
- Returns:
- < 0if socket closed and not in the middle of a message
- Throws:
- IOException- Any IOException.
 
- 
writeHeaderWrite the header, according to the header format.- Parameters:
- outputStream- The output stream.
- length- The length.
- Throws:
- IOException- Any IOException.
 
- 
readHeaderRead the header and returns the length of the data part.- Parameters:
- inputStream- The input stream.
- Returns:
- The length of the data part.
- Throws:
- IOException- Any IOException.
- SoftEndOfStreamException- if socket closes before any length data read.
 
 
-