Class ChunkedInputFilter

    • Constructor Summary

      Constructors 
      Constructor Description
      ChunkedInputFilter​(int maxTrailerSize, java.util.Set<java.lang.String> allowedTrailerHeaders, int maxExtensionSize, int maxSwallowSize)  
    • Field Detail

      • ENCODING

        protected static final ByteChunk ENCODING
      • buffer

        protected InputBuffer buffer
        Next buffer in the pipeline.
      • remaining

        protected int remaining
        Number of bytes remaining in the current chunk.
      • readChunk

        protected java.nio.ByteBuffer readChunk
        Byte chunk used to read bytes.
      • endChunk

        protected boolean endChunk
        Flag set to true when the end chunk has been read.
      • trailingHeaders

        protected final ByteChunk trailingHeaders
        Byte chunk used to store trailing headers.
      • needCRLFParse

        protected boolean needCRLFParse
        Flag set to true if the next call to doRead() must parse a CRLF pair before doing anything else.
    • Constructor Detail

      • ChunkedInputFilter

        public ChunkedInputFilter​(int maxTrailerSize,
                                  java.util.Set<java.lang.String> allowedTrailerHeaders,
                                  int maxExtensionSize,
                                  int maxSwallowSize)
    • Method Detail

      • doRead

        @Deprecated
        public int doRead​(ByteChunk chunk)
                   throws java.io.IOException
        Deprecated.
        Unused. Will be removed in Tomcat 9. Use doRead(ApplicationBufferHandler)
        Description copied from interface: InputBuffer
        Read from the input stream into the given buffer. IMPORTANT: the current model assumes that the protocol will 'own' the buffer and return a pointer to it in ByteChunk (i.e. the param will have chunk.getBytes()==null before call, and the result after the call).
        Specified by:
        doRead in interface InputBuffer
        Parameters:
        chunk - 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:
        java.io.IOException - If an I/O error occurs reading from the input stream
      • doRead

        public int doRead​(ApplicationBufferHandler handler)
                   throws java.io.IOException
        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 interface InputBuffer
        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:
        java.io.IOException - If an I/O error occurs reading from the input stream
      • setRequest

        public void setRequest​(Request request)
        Read the content length from the request.
        Specified by:
        setRequest in interface InputFilter
        Parameters:
        request - The request to be associated with this filter
      • end

        public long end()
                 throws java.io.IOException
        End the current request.
        Specified by:
        end in interface InputFilter
        Returns:
        0 is the expected return value. A positive value indicates that too many bytes were read. This method is allowed to use buffer.doRead to consume extra bytes. The result of this method can't be negative (if an error happens, an IOException should be thrown instead).
        Throws:
        java.io.IOException - If an error happens
      • available

        public int available()
        Amount of bytes still available in a buffer.
        Specified by:
        available in interface InputBuffer
        Returns:
        The number of bytes that can be read without blocking
      • setBuffer

        public void setBuffer​(InputBuffer buffer)
        Set the next buffer in the filter pipeline.
        Specified by:
        setBuffer in interface InputFilter
        Parameters:
        buffer - The next buffer
      • recycle

        public void recycle()
        Make the filter ready to process the next request.
        Specified by:
        recycle in interface InputFilter
      • getEncodingName

        public ByteChunk getEncodingName()
        Return the name of the associated encoding; Here, the value is "identity".
        Specified by:
        getEncodingName in interface InputFilter
        Returns:
        The encoding name as a byte chunk to facilitate comparison with the value read from the HTTP headers which will also be a ByteChunk
      • isFinished

        public boolean isFinished()
        Description copied from interface: InputFilter
        Has the request body been read fully?
        Specified by:
        isFinished in interface InputFilter
        Returns:
        true if the request body has been fully read, otherwise false
      • readBytes

        protected int readBytes()
                         throws java.io.IOException
        Read bytes from the previous buffer.
        Returns:
        The byte count which has been read
        Throws:
        java.io.IOException - Read error
      • parseChunkHeader

        protected boolean parseChunkHeader()
                                    throws java.io.IOException
        Parse the header of a chunk. A chunk header can look like one of the following:
        A10CRLF
        F23;chunk-extension to be ignoredCRLF

        The letters before CRLF or ';' (whatever comes first) must be valid hex digits. We should not parse F23IAMGONNAMESSTHISUP34CRLF as a valid header according to the spec.

        Returns:
        true if the chunk header has been successfully parsed
        Throws:
        java.io.IOException - Read error
      • parseCRLF

        protected void parseCRLF​(boolean tolerant)
                          throws java.io.IOException
        Parse CRLF at end of chunk.
        Parameters:
        tolerant - Should tolerant parsing (LF and CRLF) be used? This is recommended (RFC2616, section 19.3) for message headers.
        Throws:
        java.io.IOException - An error occurred parsing CRLF
      • parseEndChunk

        protected void parseEndChunk()
                              throws java.io.IOException
        Parse end chunk data.
        Throws:
        java.io.IOException - Error propagation