|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object ServletInputStream com.oreilly.servlet.multipart.BufferedServletInputStream
public class BufferedServletInputStream
A BufferedServletInputStream
wraps a
ServletInputStream
in order to provide input buffering and to
avoid calling the the readLine
method of the wrapped
ServletInputStream
.
This is necessary because some servlet containers rely on the default
implementation of the readLine
method provided by the Servlet
API classes, which is very slow. Tomcat 3.2, Tomcat 3.1, the JSWDK 1.0 web
server and the JSDK2.1 web server are all known to need this class for
performance reasons.
Also, it may be used to work around a bug in the Servlet API 2.0
implementation of readLine
which contains a bug that causes
ArrayIndexOutOfBoundsExceptions
under certain conditions.
Apache JServ is known to suffer from this bug.
Constructor Summary | |
---|---|
BufferedServletInputStream(ServletInputStream in)
Creates a BufferedServletInputStream that wraps the provided
ServletInputStream . |
Method Summary | |
---|---|
int |
read()
Implement buffering on top of the read method of
the wrapped ServletInputStream . |
int |
read(byte[] b,
int off,
int len)
Implement buffering on top of the read method of
the wrapped ServletInputStream . |
int |
readLine(byte[] b,
int off,
int len)
Implement buffering on top of the readLine method of
the wrapped ServletInputStream . |
Methods inherited from class java.lang.Object |
---|
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public BufferedServletInputStream(ServletInputStream in)
BufferedServletInputStream
that wraps the provided
ServletInputStream
.
in
- a servlet input stream.Method Detail |
---|
public int readLine(byte[] b, int off, int len) throws java.io.IOException
readLine
method of
the wrapped ServletInputStream
.
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.
java.io.IOException
- if an I/O error occurs.public int read() throws java.io.IOException
read
method of
the wrapped ServletInputStream
.
-1
if the end of the
stream is reached.
java.io.IOException
- if an I/O error occurs.public int read(byte[] b, int off, int len) throws java.io.IOException
read
method of
the wrapped ServletInputStream
.
b
- the buffer into which the data is read.off
- the start offset of the data.len
- the maximum number of bytes read.
-1
if there is no more data because the end
of the stream has been reached.
java.io.IOException
- if an I/O error occurs.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |