Package org.apache.coyote.http11
Class Http11InputBuffer
java.lang.Object
org.apache.coyote.http11.Http11InputBuffer
- All Implemented Interfaces:
InputBuffer
,HttpHeaderParser.HeaderDataSource
,ApplicationBufferHandler
public class Http11InputBuffer
extends Object
implements InputBuffer, ApplicationBufferHandler, HttpHeaderParser.HeaderDataSource
InputBuffer for HTTP that provides request header parsing as well as transfer encoding.
-
Field Summary
Fields inherited from interface org.apache.tomcat.util.net.ApplicationBufferHandler
EMPTY, EMPTY_BUFFER
-
Constructor Summary
ConstructorDescriptionHttp11InputBuffer
(Request request, int headerBufferSize, HttpParser httpParser) -
Method Summary
Modifier and TypeMethodDescriptionint
Obtain an estimate of the number of bytes that can be read without blocking.int
doRead
(ApplicationBufferHandler handler) Read from the input stream into the ByteBuffer provided by the ApplicationBufferHandler.void
expand
(int size) Expand the byte buffer to at least the given size.boolean
Read more data into the header buffer.Obtain a reference to the buffer containing the header data.void
setByteBuffer
(ByteBuffer buffer) Set the byte buffer.
-
Constructor Details
-
Http11InputBuffer
-
-
Method Details
-
doRead
Description copied from interface:InputBuffer
Read from the input stream into the ByteBuffer provided by the ApplicationBufferHandler. IMPORTANT: the current model assumes that the protocol will 'own' the ByteBuffer and return a pointer to it.- Specified by:
doRead
in interfaceInputBuffer
- Parameters:
handler
- ApplicationBufferHandler that provides the buffer to read data into.- Returns:
- The number of bytes that have been added to the buffer or -1 for end of stream
- Throws:
IOException
- If an I/O error occurs reading from the input stream
-
available
public int available()Description copied from interface:InputBuffer
Obtain an estimate of the number of bytes that can be read without blocking. Typically, this will be the number of available bytes known to be buffered.- Specified by:
available
in interfaceInputBuffer
- Returns:
- The number of bytes that can be read without blocking
-
fillHeaderBuffer
Description copied from interface:HttpHeaderParser.HeaderDataSource
Read more data into the header buffer. The implementation is expected to determine if blocking or not blocking IO should be used.- Specified by:
fillHeaderBuffer
in interfaceHttpHeaderParser.HeaderDataSource
- Returns:
true
if more data was added to the buffer, otherwisefalse
- Throws:
IOException
- If an I/O error occurred while obtaining more header data
-
setByteBuffer
Description copied from interface:ApplicationBufferHandler
Set the byte buffer.- Specified by:
setByteBuffer
in interfaceApplicationBufferHandler
- Parameters:
buffer
- the byte buffer
-
getByteBuffer
- Specified by:
getByteBuffer
in interfaceApplicationBufferHandler
- Returns:
- the byte buffer
-
getHeaderByteBuffer
Description copied from interface:HttpHeaderParser.HeaderDataSource
Obtain a reference to the buffer containing the header data.- Specified by:
getHeaderByteBuffer
in interfaceHttpHeaderParser.HeaderDataSource
- Returns:
- The buffer containing the header data
-
expand
public void expand(int size) Description copied from interface:ApplicationBufferHandler
Expand the byte buffer to at least the given size. Some implementations may not implement this.- Specified by:
expand
in interfaceApplicationBufferHandler
- Parameters:
size
- the desired size
-