Class JdkZlibDecoder
java.lang.Object
io.netty.channel.ChannelHandlerAdapter
io.netty.channel.ChannelInboundHandlerAdapter
io.netty.handler.codec.ByteToMessageDecoder
io.netty.handler.codec.compression.ZlibDecoder
io.netty.handler.codec.compression.JdkZlibDecoder
- All Implemented Interfaces:
ChannelHandler, ChannelInboundHandler
Decompress a
ByteBuf using the inflate algorithm.-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from class ByteToMessageDecoder
ByteToMessageDecoder.CumulatorNested classes/interfaces inherited from interface ChannelHandler
ChannelHandler.Sharable -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final ByteBufChecksumprivate booleanprivate final booleanprivate static final intprivate final byte[]private static final intprivate static final intprivate static final intprivate booleanprivate intprivate static final intprivate static final intprivate JdkZlibDecoder.GzipStateprivate Inflaterprivate final intprivate booleanprivate intFields inherited from class ZlibDecoder
maxAllocationFields inherited from class ByteToMessageDecoder
COMPOSITE_CUMULATOR, MERGE_CUMULATOR -
Constructor Summary
ConstructorsModifierConstructorDescriptionDeprecated.JdkZlibDecoder(boolean decompressConcatenated) Deprecated.JdkZlibDecoder(boolean decompressConcatenated, int maxAllocation) JdkZlibDecoder(byte[] dictionary) Deprecated.JdkZlibDecoder(byte[] dictionary, int maxAllocation) Creates a new instance with the specified preset dictionary and maximum buffer allocation.JdkZlibDecoder(int maxAllocation) Creates a new instance with the default wrapper (ZlibWrapper.ZLIB) and the specified maximum buffer allocation.JdkZlibDecoder(ZlibWrapper wrapper) Deprecated.JdkZlibDecoder(ZlibWrapper wrapper, boolean decompressConcatenated) Deprecated.JdkZlibDecoder(ZlibWrapper wrapper, boolean decompressConcatenated, int maxAllocation) privateJdkZlibDecoder(ZlibWrapper wrapper, byte[] dictionary, boolean decompressConcatenated, int maxAllocation) JdkZlibDecoder(ZlibWrapper wrapper, int maxAllocation) Creates a new instance with the specified wrapper and maximum buffer allocation. -
Method Summary
Modifier and TypeMethodDescriptionvoidCallsChannelHandlerContext.fireChannelReadComplete()to forward to the nextChannelInboundHandlerin theChannelPipeline.protected voiddecode(ChannelHandlerContext ctx, ByteBuf in, List<Object> out) Decode the from oneByteBufto an other.protected voiddecompressionBufferExhausted(ByteBuf buffer) Called when the decompression buffer cannot be expanded further.private booleanprotected voidGets called after theByteToMessageDecoderwas removed from the actual context and it doesn't handle events anymore.booleanisClosed()Returnstrueif and only if the end of the compressed stream has been reached.private static booleanlooksLikeZlib(short cmf_flg) private booleanRead the GZIP footer.private booleanprivate booleanskipIfNeeded(ByteBuf in, int flagMask) Skip bytes in the input if needed until we find the end marker0x00.private booleanVerifies CRC.private booleanverifyCrc16(ByteBuf in) Methods inherited from class ZlibDecoder
prepareDecompressBufferMethods inherited from class ByteToMessageDecoder
actualReadableBytes, callDecode, channelInactive, channelRead, decodeLast, discardSomeReadBytes, handlerRemoved, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode, userEventTriggeredMethods inherited from class ChannelInboundHandlerAdapter
channelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaughtMethods inherited from class ChannelHandlerAdapter
ensureNotSharable, handlerAdded, isSharableMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ChannelHandler
handlerAdded
-
Field Details
-
FHCRC
private static final int FHCRC- See Also:
-
FEXTRA
private static final int FEXTRA- See Also:
-
FNAME
private static final int FNAME- See Also:
-
FCOMMENT
private static final int FCOMMENT- See Also:
-
FRESERVED
private static final int FRESERVED- See Also:
-
inflater
-
dictionary
private final byte[] dictionary -
crc
-
decompressConcatenated
private final boolean decompressConcatenated -
gzipState
-
flags
private int flags -
xlen
private int xlen -
needsRead
private boolean needsRead -
DEFAULT_MAX_FORWARD_BYTES
private static final int DEFAULT_MAX_FORWARD_BYTES -
maxForwardBytes
private final int maxForwardBytes -
finished
private volatile boolean finished -
decideZlibOrNone
private boolean decideZlibOrNone
-
-
Constructor Details
-
JdkZlibDecoder
Deprecated.UseJdkZlibDecoder(int).Creates a new instance with the default wrapper (ZlibWrapper.ZLIB). -
JdkZlibDecoder
public JdkZlibDecoder(int maxAllocation) Creates a new instance with the default wrapper (ZlibWrapper.ZLIB) and the specified maximum buffer allocation.- Parameters:
maxAllocation- Maximum size of the decompression buffer. Must be >= 0. If zero, maximum size is decided by theByteBufAllocator.
-
JdkZlibDecoder
Deprecated.Creates a new instance with the specified preset dictionary. The wrapper is alwaysZlibWrapper.ZLIBbecause it is the only format that supports the preset dictionary. -
JdkZlibDecoder
public JdkZlibDecoder(byte[] dictionary, int maxAllocation) Creates a new instance with the specified preset dictionary and maximum buffer allocation. The wrapper is alwaysZlibWrapper.ZLIBbecause it is the only format that supports the preset dictionary.- Parameters:
maxAllocation- Maximum size of the decompression buffer. Must be >= 0. If zero, maximum size is decided by theByteBufAllocator.
-
JdkZlibDecoder
Deprecated.Creates a new instance with the specified wrapper. Be aware that onlyZlibWrapper.GZIP,ZlibWrapper.ZLIBandZlibWrapper.NONEare supported atm. -
JdkZlibDecoder
Creates a new instance with the specified wrapper and maximum buffer allocation. Be aware that onlyZlibWrapper.GZIP,ZlibWrapper.ZLIBandZlibWrapper.NONEare supported atm.- Parameters:
maxAllocation- Maximum size of the decompression buffer. Must be >= 0. If zero, maximum size is decided by theByteBufAllocator.
-
JdkZlibDecoder
Deprecated. -
JdkZlibDecoder
-
JdkZlibDecoder
Deprecated. -
JdkZlibDecoder
public JdkZlibDecoder(boolean decompressConcatenated, int maxAllocation) -
JdkZlibDecoder
private JdkZlibDecoder(ZlibWrapper wrapper, byte[] dictionary, boolean decompressConcatenated, int maxAllocation)
-
-
Method Details
-
isClosed
public boolean isClosed()Description copied from class:ZlibDecoderReturnstrueif and only if the end of the compressed stream has been reached.- Specified by:
isClosedin classZlibDecoder
-
decode
Description copied from class:ByteToMessageDecoderDecode the from oneByteBufto an other. This method will be called till either the inputByteBufhas nothing to read when return from this method or till nothing was read from the inputByteBuf.- Specified by:
decodein classByteToMessageDecoder- Parameters:
ctx- theChannelHandlerContextwhich thisByteToMessageDecoderbelongs toin- theByteBuffrom which to read dataout- theListto which decoded messages should be added- Throws:
Exception- is thrown if an error occurs
-
decompressionBufferExhausted
Description copied from class:ZlibDecoderCalled when the decompression buffer cannot be expanded further. Default implementation is a no-op, but subclasses can override in case they want to do something before theDecompressionExceptionis thrown, such as log the data that was decompressed so far.- Overrides:
decompressionBufferExhaustedin classZlibDecoder
-
handlerRemoved0
Description copied from class:ByteToMessageDecoderGets called after theByteToMessageDecoderwas removed from the actual context and it doesn't handle events anymore.- Overrides:
handlerRemoved0in classByteToMessageDecoder- Throws:
Exception
-
readGZIPHeader
-
skipIfNeeded
Skip bytes in the input if needed until we find the end marker0x00.- Parameters:
in- the inputflagMask- the mask that should be present in theflagswhen we need to skip bytes.- Returns:
trueif the operation is complete and we can move to the next state,falseif we need the retry again once we have more readable bytes.
-
verifyCrc
-
verifyCrc16
-
looksLikeZlib
private static boolean looksLikeZlib(short cmf_flg) -
channelReadComplete
Description copied from class:ChannelInboundHandlerAdapterCallsChannelHandlerContext.fireChannelReadComplete()to forward to the nextChannelInboundHandlerin theChannelPipeline. Sub-classes may override this method to change behavior.- Specified by:
channelReadCompletein interfaceChannelInboundHandler- Overrides:
channelReadCompletein classByteToMessageDecoder- Throws:
Exception
-
JdkZlibDecoder(int).