Package jakarta.servlet
Class ServletInputStream
java.lang.Object
java.io.InputStream
jakarta.servlet.ServletInputStream
- All Implemented Interfaces:
- Closeable,- AutoCloseable
Provides an input stream for reading binary data from a client request, including an efficient 
readLine
 method for reading data one line at a time. With some protocols, such as HTTP POST and PUT, a
 ServletInputStream object can be used to read data sent from the client.
 
 A ServletInputStream object is normally retrieved via the ServletRequest.getInputStream() method.
 
 This is an abstract class that a servlet container implements. Subclasses of this class must implement the
 java.io.InputStream.read() method.
- See Also:
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDoes nothing, because this is an abstract class.
- 
Method SummaryModifier and TypeMethodDescriptionabstract booleanReturns true when all the data from the stream has been read else it returns false.abstract booleanisReady()Returns true if data can be read without blocking else returns false.intreadLine(byte[] b, int off, int len) Reads the input stream, one line at a time.abstract voidsetReadListener(ReadListener readListener) Instructs theServletInputStreamto invoke the providedReadListenerwhen it is possible to readMethods inherited from class java.io.InputStreamavailable, close, mark, markSupported, nullInputStream, read, read, read, readAllBytes, readNBytes, readNBytes, reset, skip, skipNBytes, transferTo
- 
Constructor Details- 
ServletInputStreamprotected ServletInputStream()Does nothing, because this is an abstract class.
 
- 
- 
Method Details- 
readLineReads the input stream, one line at a time. Starting at an offset, reads bytes into an array, until it reads a certain number of bytes or reaches a newline character, which it reads into the array as well.This method returns -1 if it reaches the end of the input stream before reading the maximum number of bytes. - Parameters:
- b- an array of bytes into which data is read
- off- an integer specifying the character at which this method begins reading
- len- an integer specifying the maximum number of bytes to read
- Returns:
- an integer specifying the actual number of bytes read, or -1 if the end of the stream is reached
- Throws:
- IOException- if an input or output exception has occurred
 
- 
isFinishedpublic abstract boolean isFinished()Returns true when all the data from the stream has been read else it returns false.- Returns:
- truewhen all data for this particular request has been read, otherwise returns- false.
- Since:
- Servlet 3.1
 
- 
isReadypublic abstract boolean isReady()Returns true if data can be read without blocking else returns false.- Returns:
- trueif data can be obtained without blocking, otherwise returns- false.
- Since:
- Servlet 3.1
 
- 
setReadListenerInstructs theServletInputStreamto invoke the providedReadListenerwhen it is possible to read- Parameters:
- readListener- the- ReadListenerthat should be notified when it's possible to read.
- Throws:
- IllegalStateException- if one of the following conditions is true- the associated request is neither upgraded nor the async started
- setReadListener is called more than once within the scope of the same request.
 
- NullPointerException- if readListener is null
- Since:
- Servlet 3.1
 
 
-