public class HttpResponseDecoder extends HttpObjectDecoder
ByteBuf
s into HttpResponse
s and
HttpContent
s.
Name | Meaning |
---|---|
maxInitialLineLength |
The maximum length of the initial line (e.g. "HTTP/1.0 200 OK" )
If the length of the initial line exceeds this value, a
TooLongFrameException will be raised. |
maxHeaderSize |
The maximum length of all headers. If the sum of the length of each
header exceeds this value, a TooLongFrameException will be raised. |
maxChunkSize |
The maximum length of the content or each chunk. If the content length
exceeds this value, the transfer encoding of the decoded response will be
converted to 'chunked' and the content will be split into multiple
HttpContent s. If the transfer encoding of the HTTP response 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 handle
HttpContent s in your handler, insert HttpObjectAggregator
after this decoder in the ChannelPipeline . |
Unlike other HTTP requests, the successful response of a HEAD
request does not have any content even if there is Content-Length
header. Because HttpResponseDecoder
is not able to determine if the
response currently being decoded is associated with a HEAD request,
you must override HttpObjectDecoder.isContentAlwaysEmpty(HttpMessage)
to return
true for the response of the HEAD request.
If you are writing an HTTP client that issues a HEAD request,
please use HttpClientCodec
instead of this decoder. It will perform
additional state management to handle the responses for HEAD
requests correctly.
You also need to do additional state management to handle the response of a CONNECT request properly, like you did for HEAD. One difference is that the decoder should stop decoding completely after decoding the successful 200 response since the connection is not an HTTP connection anymore.
HttpClientCodec
also handles this edge case correctly, so you have to
use HttpClientCodec
if you are writing an HTTP client that issues a
CONNECT request.
ByteToMessageDecoder.Cumulator
ChannelHandler.Sharable
validateHeaders
COMPOSITE_CUMULATOR, MERGE_CUMULATOR
构造器和说明 |
---|
HttpResponseDecoder()
Creates a new instance with the default
maxInitialLineLength (4096) , maxHeaderSize (8192) , and
maxChunkSize (8192) . |
HttpResponseDecoder(int maxInitialLineLength,
int maxHeaderSize,
int maxChunkSize)
Creates a new instance with the specified parameters.
|
HttpResponseDecoder(int maxInitialLineLength,
int maxHeaderSize,
int maxChunkSize,
boolean validateHeaders) |
HttpResponseDecoder(int maxInitialLineLength,
int maxHeaderSize,
int maxChunkSize,
boolean validateHeaders,
int initialBufferSize) |
限定符和类型 | 方法和说明 |
---|---|
protected HttpMessage |
createInvalidMessage() |
protected HttpMessage |
createMessage(java.lang.String[] initialLine) |
protected boolean |
isDecodingRequest() |
decode, decodeLast, isContentAlwaysEmpty, isSwitchingToNonHttp1Protocol, reset, userEventTriggered
actualReadableBytes, callDecode, channelInactive, channelRead, channelReadComplete, discardSomeReadBytes, handlerRemoved, handlerRemoved0, internalBuffer, isSingleDecode, setCumulator, setDiscardAfterReads, setSingleDecode
channelActive, channelRegistered, channelUnregistered, channelWritabilityChanged, exceptionCaught
ensureNotSharable, handlerAdded, isSharable
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
handlerAdded
public HttpResponseDecoder()
maxInitialLineLength (4096)
, maxHeaderSize (8192)
, and
maxChunkSize (8192)
.public HttpResponseDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize)
public HttpResponseDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders)
public HttpResponseDecoder(int maxInitialLineLength, int maxHeaderSize, int maxChunkSize, boolean validateHeaders, int initialBufferSize)
protected HttpMessage createMessage(java.lang.String[] initialLine)
createMessage
在类中 HttpObjectDecoder
protected HttpMessage createInvalidMessage()
createInvalidMessage
在类中 HttpObjectDecoder
protected boolean isDecodingRequest()
isDecodingRequest
在类中 HttpObjectDecoder