Package io.netty.handler.codec.http
Class HttpRequestDecoder
- java.lang.Object
-
- io.netty.channel.ChannelHandlerAdapter
-
- io.netty.channel.ChannelInboundHandlerAdapter
-
- io.netty.handler.codec.ByteToMessageDecoder
-
- io.netty.handler.codec.http.HttpObjectDecoder
-
- io.netty.handler.codec.http.HttpRequestDecoder
-
- All Implemented Interfaces:
ChannelHandler,ChannelInboundHandler
- Direct Known Subclasses:
HttpServerCodec.HttpServerRequestDecoder
public class HttpRequestDecoder extends HttpObjectDecoder
DecodesByteBufs intoHttpRequests andHttpContents.Parameters that prevents excessive memory consumption
Name Meaning maxInitialLineLengthThe maximum length of the initial line (e.g. "GET / HTTP/1.0") If the length of the initial line exceeds this value, aTooLongHttpLineExceptionwill be raised.maxHeaderSizeThe maximum length of all headers. If the sum of the length of each header exceeds this value, a TooLongHttpHeaderExceptionwill be raised.maxChunkSizeThe maximum length of the content or each chunk. If the content length exceeds this value, the transfer encoding of the decoded request will be converted to 'chunked' and the content will be split into multiple HttpContents. If the transfer encoding of the HTTP request is 'chunked' already, each chunk will be split into smaller chunks if the length of the chunk exceeds this value. If you prefer not to handleHttpContents in your handler, insertHttpObjectAggregatorafter this decoder in theChannelPipeline.Parameters that control parsing behavior
Name Default value Meaning allowDuplicateContentLengthsfalse When set to false, will reject any messages that contain multiple Content-Length header fields. When set totrue, will allow multiple Content-Length headers only if they are all the same decimal value. The duplicated field-values will be replaced with a single valid Content-Length field. See RFC 7230, Section 3.3.2.allowPartialChunkstrue If the length of a chunk exceeds the ByteBufs readable bytes andallowPartialChunksis set totrue, the chunk will be split into multipleHttpContents. Otherwise, if the chunk size does not exceedmaxChunkSizeandallowPartialChunksis set tofalse, theByteBufis not decoded into anHttpContentuntil the readable bytes are greater or equal to the chunk size.Header Validation
It is recommended to always enable header validation.Without header validation, your system can become vulnerable to CWE-113: Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Response Splitting') .
This recommendation stands even when both peers in the HTTP exchange are trusted, as it helps with defence-in-depth.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class io.netty.handler.codec.ByteToMessageDecoder
ByteToMessageDecoder.Cumulator
-
Nested classes/interfaces inherited from interface io.netty.channel.ChannelHandler
ChannelHandler.Sharable
-
-
Field Summary
Fields Modifier and Type Field Description private static AsciiStringAcceptprivate static longACCEPT_AS_LONGprivate static AsciiStringConnectionprivate static longCONNECTION_AS_LONG_0private static shortCONNECTION_AS_SHORT_1private static longCONTENT_AS_LONGprivate static AsciiStringContentLengthprivate static AsciiStringContentTypeprivate static intGET_AS_INTprivate static AsciiStringHostprivate static intHOST_AS_INTprivate static longHTTP_1_0_AS_LONGprivate static longHTTP_1_1_AS_LONGprivate static longLENGTH_AS_LONGprivate static intPOST_AS_INTprivate static intTYPE_AS_INT-
Fields inherited from class io.netty.handler.codec.http.HttpObjectDecoder
DEFAULT_ALLOW_DUPLICATE_CONTENT_LENGTHS, DEFAULT_ALLOW_PARTIAL_CHUNKS, DEFAULT_CHUNKED_SUPPORTED, DEFAULT_INITIAL_BUFFER_SIZE, DEFAULT_MAX_CHUNK_SIZE, DEFAULT_MAX_HEADER_SIZE, DEFAULT_MAX_INITIAL_LINE_LENGTH, DEFAULT_STRICT_LINE_PARSING, DEFAULT_VALIDATE_HEADERS, headersFactory, trailersFactory, validateHeaders
-
Fields inherited from class io.netty.handler.codec.ByteToMessageDecoder
COMPOSITE_CUMULATOR, MERGE_CUMULATOR
-
-
Constructor Summary
Constructors Constructor Description HttpRequestDecoder()Creates a new instance with the defaultmaxInitialLineLength (4096),maxHeaderSize (8192), andmaxChunkSize (8192).HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize)Creates a new instance with the specified parameters.HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize, boolean allowDuplicateContentLengths)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize, boolean allowDuplicateContentLengths, boolean allowPartialChunks)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.HttpRequestDecoder(HttpDecoderConfig config)Creates a new instance with the specified configuration.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected HttpMessagecreateInvalidMessage()protected HttpMessagecreateMessage(java.lang.String[] initialLine)private static booleanisAccept(byte[] sb, int start)private static booleanisConnection(byte[] sb, int start)protected booleanisContentAlwaysEmpty(HttpMessage msg)private static booleanisContentLength(byte[] sb, int start)private static booleanisContentType(byte[] sb, int start)protected booleanisDecodingRequest()private static booleanisGetMethod(byte[] sb, int start)private static booleanisHost(byte[] sb, int start)private static booleanisPostMethod(byte[] sb, int start)protected java.lang.StringsplitFirstWordInitialLine(byte[] sb, int start, int length)protected AsciiStringsplitHeaderName(byte[] sb, int start, int length)protected java.lang.StringsplitThirdWordInitialLine(byte[] sb, int start, int length)-
Methods inherited from class io.netty.handler.codec.http.HttpObjectDecoder
decode, decodeLast, handlerRemoved0, handleTransferEncodingChunkedWithContentLength, isSwitchingToNonHttp1Protocol, isValidating, reset, splitSecondWordInitialLine, userEventTriggered
-
Methods inherited from class io.netty.handler.codec.ByteToMessageDecoder
actualReadableBytes, callDecode, channelInactive, channelRead, channelReadComplete, discardSomeReadBytes, handlerRemoved, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode
-
Methods inherited from class io.netty.channel.ChannelInboundHandlerAdapter
channelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaught
-
Methods inherited from class io.netty.channel.ChannelHandlerAdapter
ensureNotSharable, handlerAdded, isSharable
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface io.netty.channel.ChannelHandler
handlerAdded
-
-
-
-
Field Detail
-
Accept
private static final AsciiString Accept
-
Host
private static final AsciiString Host
-
Connection
private static final AsciiString Connection
-
ContentType
private static final AsciiString ContentType
-
ContentLength
private static final AsciiString ContentLength
-
GET_AS_INT
private static final int GET_AS_INT
- See Also:
- Constant Field Values
-
POST_AS_INT
private static final int POST_AS_INT
- See Also:
- Constant Field Values
-
HTTP_1_1_AS_LONG
private static final long HTTP_1_1_AS_LONG
- See Also:
- Constant Field Values
-
HTTP_1_0_AS_LONG
private static final long HTTP_1_0_AS_LONG
- See Also:
- Constant Field Values
-
HOST_AS_INT
private static final int HOST_AS_INT
- See Also:
- Constant Field Values
-
CONNECTION_AS_LONG_0
private static final long CONNECTION_AS_LONG_0
- See Also:
- Constant Field Values
-
CONNECTION_AS_SHORT_1
private static final short CONNECTION_AS_SHORT_1
- See Also:
- Constant Field Values
-
CONTENT_AS_LONG
private static final long CONTENT_AS_LONG
- See Also:
- Constant Field Values
-
TYPE_AS_INT
private static final int TYPE_AS_INT
- See Also:
- Constant Field Values
-
LENGTH_AS_LONG
private static final long LENGTH_AS_LONG
- See Also:
- Constant Field Values
-
ACCEPT_AS_LONG
private static final long ACCEPT_AS_LONG
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
HttpRequestDecoder
public HttpRequestDecoder()
Creates a new instance with the defaultmaxInitialLineLength (4096),maxHeaderSize (8192), andmaxChunkSize (8192).
-
HttpRequestDecoder
public HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize)Creates a new instance with the specified parameters.- Parameters:
maxInitialLineLength- the initial size of the temporary buffer used when parsing the lines of the HTTP headers.maxHeaderSize- the maximum permitted combined size of all headers in any one request.maxChunkSize- The maximum amount of data that the decoder will buffer before sending chunks down the pipeline.- See Also:
HttpDecoderConfig API documentation for detailed descriptions of the configuration parameters.
-
HttpRequestDecoder
@Deprecated public HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.
-
HttpRequestDecoder
@Deprecated public HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.
-
HttpRequestDecoder
@Deprecated public HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize, boolean allowDuplicateContentLengths)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.
-
HttpRequestDecoder
@Deprecated public HttpRequestDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize, boolean allowDuplicateContentLengths, boolean allowPartialChunks)Deprecated.Prefer theHttpRequestDecoder(HttpDecoderConfig)constructor, to always have header validation enabled.
-
HttpRequestDecoder
public HttpRequestDecoder(HttpDecoderConfig config)
Creates a new instance with the specified configuration.
-
-
Method Detail
-
createMessage
protected HttpMessage createMessage(java.lang.String[] initialLine) throws java.lang.Exception
- Specified by:
createMessagein classHttpObjectDecoder- Throws:
java.lang.Exception
-
splitHeaderName
protected AsciiString splitHeaderName(byte[] sb, int start, int length)
- Overrides:
splitHeaderNamein classHttpObjectDecoder
-
isAccept
private static boolean isAccept(byte[] sb, int start)
-
isHost
private static boolean isHost(byte[] sb, int start)
-
isConnection
private static boolean isConnection(byte[] sb, int start)
-
isContentType
private static boolean isContentType(byte[] sb, int start)
-
isContentLength
private static boolean isContentLength(byte[] sb, int start)
-
isGetMethod
private static boolean isGetMethod(byte[] sb, int start)
-
isPostMethod
private static boolean isPostMethod(byte[] sb, int start)
-
splitFirstWordInitialLine
protected java.lang.String splitFirstWordInitialLine(byte[] sb, int start, int length)- Overrides:
splitFirstWordInitialLinein classHttpObjectDecoder
-
splitThirdWordInitialLine
protected java.lang.String splitThirdWordInitialLine(byte[] sb, int start, int length)- Overrides:
splitThirdWordInitialLinein classHttpObjectDecoder
-
createInvalidMessage
protected HttpMessage createInvalidMessage()
- Specified by:
createInvalidMessagein classHttpObjectDecoder
-
isDecodingRequest
protected boolean isDecodingRequest()
- Specified by:
isDecodingRequestin classHttpObjectDecoder
-
isContentAlwaysEmpty
protected boolean isContentAlwaysEmpty(HttpMessage msg)
- Overrides:
isContentAlwaysEmptyin classHttpObjectDecoder
-
-