public class LenientDelimiterBasedFrameDecoder
extends io.netty.handler.codec.ByteToMessageDecoder
ByteBufs by one or more
delimiters. It is particularly useful for decoding the frames which ends
with a delimiter such as NUL or
newline characters.
Delimiters defines frequently used delimiters for convenience' sake.
LenientDelimiterBasedFrameDecoder allows you to specify more than one
delimiter. If more than one delimiter is found in the buffer, it chooses
the delimiter which produces the shortest frame. For example, if you have
the following data in the buffer:
+--------------+ | ABC\nDEF\r\n | +--------------+a
LenientDelimiterBasedFrameDecoder(Delimiters.lineDelimiter())
will choose '\n' as the first delimiter and produce two frames:
+-----+-----+ | ABC | DEF | +-----+-----+rather than incorrectly choosing
'\r\n' as the first delimiter:
+----------+ | ABC\nDEF | +----------+
| Constructor and Description |
|---|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
boolean failFast,
boolean emitLastLineWithoutDelimiter,
io.netty.buffer.ByteBuf... delimiters)
Creates a new instance.
|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
boolean failFast,
io.netty.buffer.ByteBuf delimiter)
Creates a new instance.
|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
io.netty.buffer.ByteBuf... delimiters)
Creates a new instance.
|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
io.netty.buffer.ByteBuf delimiter)
Creates a new instance.
|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
io.netty.buffer.ByteBuf... delimiters)
Creates a new instance.
|
LenientDelimiterBasedFrameDecoder(int maxFrameLength,
io.netty.buffer.ByteBuf delimiter)
Creates a new instance.
|
| Modifier and Type | Method and Description |
|---|---|
protected Object |
decode(io.netty.channel.ChannelHandlerContext ctx,
io.netty.buffer.ByteBuf buffer)
Create a frame out of the
ByteBuf and return it. |
protected void |
decode(io.netty.channel.ChannelHandlerContext ctx,
io.netty.buffer.ByteBuf in,
List<Object> out) |
actualReadableBytes, callDecode, channelInactive, channelRead, channelReadComplete, decodeLast, discardSomeReadBytes, handlerRemoved, handlerRemoved0, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode, userEventTriggeredchannelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaughtensureNotSharable, handlerAdded, isSharablepublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
io.netty.buffer.ByteBuf delimiter)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.delimiter - the delimiterpublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
io.netty.buffer.ByteBuf delimiter)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.stripDelimiter - whether the decoded frame should strip out the
delimiter or notdelimiter - the delimiterpublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
boolean failFast,
io.netty.buffer.ByteBuf delimiter)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.stripDelimiter - whether the decoded frame should strip out the
delimiter or notfailFast - If true, a TooLongFrameException is
thrown as soon as the decoder notices the length of the
frame will exceed maxFrameLength regardless of
whether the entire frame has been read.
If false, a TooLongFrameException is
thrown after the entire frame that exceeds
maxFrameLength has been read.delimiter - the delimiterpublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
io.netty.buffer.ByteBuf... delimiters)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.delimiters - the delimiterspublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
io.netty.buffer.ByteBuf... delimiters)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.stripDelimiter - whether the decoded frame should strip out the
delimiter or notdelimiters - the delimiterspublic LenientDelimiterBasedFrameDecoder(int maxFrameLength,
boolean stripDelimiter,
boolean failFast,
boolean emitLastLineWithoutDelimiter,
io.netty.buffer.ByteBuf... delimiters)
maxFrameLength - the maximum length of the decoded frame.
A TooLongFrameException is thrown if
the length of the frame exceeds this value.stripDelimiter - whether the decoded frame should strip out the
delimiter or notfailFast - If true, a TooLongFrameException is
thrown as soon as the decoder notices the length of the
frame will exceed maxFrameLength regardless of
whether the entire frame has been read.
If false, a TooLongFrameException is
thrown after the entire frame that exceeds
maxFrameLength has been read.emitLastLineWithoutDelimiter - emit the last line even if it doesn't
end with the delimiterdelimiters - the delimitersprotected final void decode(io.netty.channel.ChannelHandlerContext ctx,
io.netty.buffer.ByteBuf in,
List<Object> out)
throws Exception
decode in class io.netty.handler.codec.ByteToMessageDecoderExceptionprotected Object decode(io.netty.channel.ChannelHandlerContext ctx, io.netty.buffer.ByteBuf buffer) throws Exception
ByteBuf and return it.ctx - the ChannelHandlerContext which this ByteToMessageDecoder belongs tobuffer - the ByteBuf from which to read dataByteBuf which represent the frame or null if no frame could
be created.ExceptionCopyright © 2012–2021 Graylog, Inc.. All rights reserved.