Package org.springframework.core.codec
Class CharBufferDecoder
java.lang.Object
org.springframework.core.codec.AbstractDecoder<T>
org.springframework.core.codec.AbstractDataBufferDecoder<T>
org.springframework.core.codec.AbstractCharSequenceDecoder<CharBuffer>
org.springframework.core.codec.CharBufferDecoder
- All Implemented Interfaces:
Decoder<CharBuffer>
Decode from a data buffer stream to a
CharBuffer stream, either splitting
or aggregating incoming data chunks to realign along newlines delimiters
and produce a stream of char buffers. This is useful for streaming but is also
necessary to ensure that multi-byte characters can be decoded correctly,
avoiding split-character issues. The default delimiters used by default are
\n and \r\n but that can be customized.- Since:
- 6.1
- Author:
- Markus Heiden, Arjen Poutsma
- See Also:
-
Field Summary
Fields inherited from class org.springframework.core.codec.AbstractCharSequenceDecoder
DEFAULT_CHARSET, DEFAULT_DELIMITERSFields inherited from class org.springframework.core.codec.AbstractDecoder
logger -
Constructor Summary
ConstructorsConstructorDescriptionCharBufferDecoder(List<String> delimiters, boolean stripDelimiter, MimeType... mimeTypes) -
Method Summary
Modifier and TypeMethodDescriptionstatic CharBufferDecoderCreate aCharBufferDecoderthat supports all MIME types.static CharBufferDecoderallMimeTypes(List<String> delimiters, boolean stripDelimiter) Create aCharBufferDecoderthat supports all MIME types.booleancanDecode(ResolvableType elementType, @Nullable MimeType mimeType) Whether the decoder supports the given target element type and the MIME type of the source stream.protected CharBufferdecodeInternal(DataBuffer dataBuffer, Charset charset) Template method that decodes the given data buffer intoT, given the charset.static CharBufferDecoderCreate aCharBufferDecoderfor"text/plain".static CharBufferDecodertextPlainOnly(List<String> delimiters, boolean stripDelimiter) Create aCharBufferDecoderfor"text/plain".Methods inherited from class org.springframework.core.codec.AbstractCharSequenceDecoder
decode, decode, getDefaultCharset, setDefaultCharsetMethods inherited from class org.springframework.core.codec.AbstractDataBufferDecoder
decodeDataBuffer, decodeToMono, getMaxInMemorySize, setMaxInMemorySizeMethods inherited from class org.springframework.core.codec.AbstractDecoder
getDecodableMimeTypes, getLogger, setLoggerMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.core.codec.Decoder
getDecodableMimeTypes
-
Constructor Details
-
CharBufferDecoder
-
-
Method Details
-
canDecode
Description copied from interface:DecoderWhether the decoder supports the given target element type and the MIME type of the source stream.- Specified by:
canDecodein interfaceDecoder<CharBuffer>- Overrides:
canDecodein classAbstractDecoder<CharBuffer>- Parameters:
elementType- the target element type for the output streammimeType- the mime type associated with the stream to decode (can benullif not specified)- Returns:
trueif supported,falseotherwise
-
decodeInternal
Description copied from class:AbstractCharSequenceDecoderTemplate method that decodes the given data buffer intoT, given the charset.- Specified by:
decodeInternalin classAbstractCharSequenceDecoder<CharBuffer>
-
textPlainOnly
Create aCharBufferDecoderfor"text/plain". -
textPlainOnly
Create aCharBufferDecoderfor"text/plain".- Parameters:
delimiters- delimiter strings to use to split the input streamstripDelimiter- whether to remove delimiters from the resulting input strings
-
allMimeTypes
Create aCharBufferDecoderthat supports all MIME types. -
allMimeTypes
Create aCharBufferDecoderthat supports all MIME types.- Parameters:
delimiters- delimiter strings to use to split the input streamstripDelimiter- whether to remove delimiters from the resulting input strings
-