Class ChunkedOutputStream

java.lang.Object
java.io.OutputStream
org.apache.http.impl.io.ChunkedOutputStream
All Implemented Interfaces:
Closeable, Flushable, AutoCloseable

public class ChunkedOutputStream extends OutputStream
Implements chunked transfer coding. The content is sent in small chunks. Entities transferred using this output stream can be of unlimited length. Writes are buffered to an internal buffer (2048 default size).

Note that this class NEVER closes the underlying stream, even when close gets called. Instead, the stream will be marked as closed and no further output will be permitted.

Since:
4.0
  • Field Details

    • out

      private final SessionOutputBuffer out
    • cache

      private final byte[] cache
    • cachePosition

      private int cachePosition
    • wroteLastChunk

      private boolean wroteLastChunk
    • closed

      private boolean closed
      True if the stream is closed.
  • Constructor Details

  • Method Details

    • flushCache

      protected void flushCache() throws IOException
      Writes the cache out onto the underlying stream
      Throws:
      IOException
    • flushCacheWithAppend

      protected void flushCacheWithAppend(byte[] bufferToAppend, int off, int len) throws IOException
      Writes the cache and bufferToAppend to the underlying stream as one large chunk
      Throws:
      IOException
    • writeClosingChunk

      protected void writeClosingChunk() throws IOException
      Throws:
      IOException
    • finish

      public void finish() throws IOException
      Must be called to ensure the internal cache is flushed and the closing chunk is written.
      Throws:
      IOException - in case of an I/O error
    • write

      public void write(int b) throws IOException
      Specified by:
      write in class OutputStream
      Throws:
      IOException
    • write

      public void write(byte[] b) throws IOException
      Writes the array. If the array does not fit within the buffer, it is not split, but rather written out as one large chunk.
      Overrides:
      write in class OutputStream
      Throws:
      IOException
    • write

      public void write(byte[] src, int off, int len) throws IOException
      Writes the array. If the array does not fit within the buffer, it is not split, but rather written out as one large chunk.
      Overrides:
      write in class OutputStream
      Throws:
      IOException
    • flush

      public void flush() throws IOException
      Flushes the content buffer and the underlying stream.
      Specified by:
      flush in interface Flushable
      Overrides:
      flush in class OutputStream
      Throws:
      IOException
    • close

      public void close() throws IOException
      Finishes writing to the underlying stream, but does NOT close the underlying stream.
      Specified by:
      close in interface AutoCloseable
      Specified by:
      close in interface Closeable
      Overrides:
      close in class OutputStream
      Throws:
      IOException