All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.netty.handler.codec.http.HttpDecoderConfig Maven / Gradle / Ivy

Go to download

This artifact provides a single jar that contains all classes required to use remote Jakarta Enterprise Beans and Jakarta Messaging, including all dependencies. It is intended for use by those not using maven, maven users should just import the Jakarta Enterprise Beans and Jakarta Messaging BOM's instead (shaded JAR's cause lots of problems with maven, as it is very easy to inadvertently end up with different versions on classes on the class path).

There is a newer version: 35.0.0.Beta1
Show newest version
/*
 * Copyright 2023 The Netty Project
 *
 * The Netty Project licenses this file to you under the Apache License,
 * version 2.0 (the "License"); you may not use this file except in compliance
 * with the License. You may obtain a copy of the License at:
 *
 *   https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations
 * under the License.
 */
package io.netty.handler.codec.http;

import static io.netty.util.internal.ObjectUtil.checkNotNull;
import static io.netty.util.internal.ObjectUtil.checkPositive;

/**
 * A configuration object for specifying the behaviour of {@link HttpObjectDecoder} and its subclasses.
 * 

* The {@link HttpDecoderConfig} objects are mutable to reduce allocation, * but also {@link Cloneable} in case a defensive copy is needed. */ public final class HttpDecoderConfig implements Cloneable { private int maxChunkSize = HttpObjectDecoder.DEFAULT_MAX_CHUNK_SIZE; private boolean chunkedSupported = HttpObjectDecoder.DEFAULT_CHUNKED_SUPPORTED; private boolean allowPartialChunks = HttpObjectDecoder.DEFAULT_ALLOW_PARTIAL_CHUNKS; private HttpHeadersFactory headersFactory = DefaultHttpHeadersFactory.headersFactory(); private HttpHeadersFactory trailersFactory = DefaultHttpHeadersFactory.trailersFactory(); private boolean allowDuplicateContentLengths = HttpObjectDecoder.DEFAULT_ALLOW_DUPLICATE_CONTENT_LENGTHS; private int maxInitialLineLength = HttpObjectDecoder.DEFAULT_MAX_INITIAL_LINE_LENGTH; private int maxHeaderSize = HttpObjectDecoder.DEFAULT_MAX_HEADER_SIZE; private int initialBufferSize = HttpObjectDecoder.DEFAULT_INITIAL_BUFFER_SIZE; public int getInitialBufferSize() { return initialBufferSize; } /** * Set the initial size of the temporary buffer used when parsing the lines of the HTTP headers. * * @param initialBufferSize The buffer size in bytes. * @return This decoder config. */ public HttpDecoderConfig setInitialBufferSize(int initialBufferSize) { checkPositive(initialBufferSize, "initialBufferSize"); this.initialBufferSize = initialBufferSize; return this; } public int getMaxInitialLineLength() { return maxInitialLineLength; } /** * Set the maximum length of the first line of the HTTP header. * This limits how much memory Netty will use when parsed the initial HTTP header line. * You would typically set this to the same value as {@link #setMaxHeaderSize(int)}. * * @param maxInitialLineLength The maximum length, in bytes. * @return This decoder config. */ public HttpDecoderConfig setMaxInitialLineLength(int maxInitialLineLength) { checkPositive(maxInitialLineLength, "maxInitialLineLength"); this.maxInitialLineLength = maxInitialLineLength; return this; } public int getMaxHeaderSize() { return maxHeaderSize; } /** * Set the maximum line length of header lines. * This limits how much memory Netty will use when parsing HTTP header key-value pairs. * You would typically set this to the same value as {@link #setMaxInitialLineLength(int)}. * * @param maxHeaderSize The maximum length, in bytes. * @return This decoder config. */ public HttpDecoderConfig setMaxHeaderSize(int maxHeaderSize) { checkPositive(maxHeaderSize, "maxHeaderSize"); this.maxHeaderSize = maxHeaderSize; return this; } public int getMaxChunkSize() { return maxChunkSize; } /** * Set the maximum chunk size. * HTTP requests and responses can be quite large, in which case it's better to process the data as a stream of * chunks. * This sets the limit, in bytes, at which Netty will send a chunk down the pipeline. * * @param maxChunkSize The maximum chunk size, in bytes. * @return This decoder config. */ public HttpDecoderConfig setMaxChunkSize(int maxChunkSize) { checkPositive(maxChunkSize, "maxChunkSize"); this.maxChunkSize = maxChunkSize; return this; } public boolean isChunkedSupported() { return chunkedSupported; } /** * Set whether {@code Transfer-Encoding: Chunked} should be supported. * * @param chunkedSupported if {@code false}, then a {@code Transfer-Encoding: Chunked} header will produce an error, * instead of a stream of chunks. * @return This decoder config. */ public HttpDecoderConfig setChunkedSupported(boolean chunkedSupported) { this.chunkedSupported = chunkedSupported; return this; } public boolean isAllowPartialChunks() { return allowPartialChunks; } /** * Set whether chunks can be split into multiple messages, if their chunk size exceeds the size of the input buffer. * * @param allowPartialChunks set to {@code false} to only allow sending whole chunks down the pipeline. * @return This decoder config. */ public HttpDecoderConfig setAllowPartialChunks(boolean allowPartialChunks) { this.allowPartialChunks = allowPartialChunks; return this; } public HttpHeadersFactory getHeadersFactory() { return headersFactory; } /** * Set the {@link HttpHeadersFactory} to use when creating new HTTP headers objects. * The default headers factory is {@link DefaultHttpHeadersFactory#headersFactory()}. *

* For the purpose of {@link #clone()}, it is assumed that the factory is either immutable, or can otherwise be * shared across different decoders and decoder configs. * * @param headersFactory The header factory to use. * @return This decoder config. */ public HttpDecoderConfig setHeadersFactory(HttpHeadersFactory headersFactory) { checkNotNull(headersFactory, "headersFactory"); this.headersFactory = headersFactory; return this; } public boolean isAllowDuplicateContentLengths() { return allowDuplicateContentLengths; } /** * Set whether more than one {@code Content-Length} header is allowed. * You usually want to disallow this (which is the default) as multiple {@code Content-Length} headers can indicate * a request- or response-splitting attack. * * @param allowDuplicateContentLengths set to {@code true} to allow multiple content length headers. * @return This decoder config. */ public HttpDecoderConfig setAllowDuplicateContentLengths(boolean allowDuplicateContentLengths) { this.allowDuplicateContentLengths = allowDuplicateContentLengths; return this; } /** * Set whether header validation should be enabled or not. * This works by changing the configured {@linkplain #setHeadersFactory(HttpHeadersFactory) header factory} * and {@linkplain #setTrailersFactory(HttpHeadersFactory) trailer factory}. *

* You usually want header validation enabled (which is the default) in order to prevent request-/response-splitting * attacks. * * @param validateHeaders set to {@code false} to disable header validation. * @return This decoder config. */ public HttpDecoderConfig setValidateHeaders(boolean validateHeaders) { DefaultHttpHeadersFactory noValidation = DefaultHttpHeadersFactory.headersFactory().withValidation(false); headersFactory = validateHeaders ? DefaultHttpHeadersFactory.headersFactory() : noValidation; trailersFactory = validateHeaders ? DefaultHttpHeadersFactory.trailersFactory() : noValidation; return this; } public HttpHeadersFactory getTrailersFactory() { return trailersFactory; } /** * Set the {@link HttpHeadersFactory} used to create HTTP trailers. * This differs from {@link #setHeadersFactory(HttpHeadersFactory)} in that trailers have different validation * requirements. * The default trailer factory is {@link DefaultHttpHeadersFactory#headersFactory()}. *

* For the purpose of {@link #clone()}, it is assumed that the factory is either immutable, or can otherwise be * shared across different decoders and decoder configs. * * @param trailersFactory The headers factory to use for creating trailers. * @return This decoder config. */ public HttpDecoderConfig setTrailersFactory(HttpHeadersFactory trailersFactory) { checkNotNull(trailersFactory, "trailersFactory"); this.trailersFactory = trailersFactory; return this; } @Override public HttpDecoderConfig clone() { try { return (HttpDecoderConfig) super.clone(); } catch (CloneNotSupportedException e) { throw new AssertionError(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy