- java.lang.Object
-
- org.eclipse.jetty.server.MultiPartFormInputStream
-
public class MultiPartFormInputStream extends java.lang.ObjectMultiPartInputStreamHandle a MultiPart Mime input stream, breaking it up on the boundary into files and strings.
Deleting the parts can be done from a different thread if the parts are parsed asynchronously. Because of this we use the state to fail the parsing and coordinate which thread will delete any remaining parts. The deletion of parts is done by the cleanup thread in all cases except the transition from DELETING->DELETED which is done by the parsing thread.
UNPARSED - Parsing has not started, there are no parts which need to be cleaned up. PARSING - The parsing thread is reading from the InputStream and generating parts. PARSED - Parsing has complete and no more parts will be generated. DELETING - deleteParts() has been called while we were in PARSING state, parsing thread will do the delete. DELETED - The parts have been deleted, this is the terminal state. deleteParts() +--------------------------------------------------------------+ | | | deleteParts() v UNPARSED -------> PARSING --------> PARSED ------------------>DELETED | ^ | | +---------------> DELETING -------------------+ deleteParts() parsing thread- See Also:
- https://tools.ietf.org/html/rfc7578
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description classMultiPartFormInputStream.MultiPart
-
Constructor Summary
Constructors Constructor Description MultiPartFormInputStream(java.io.InputStream in, java.lang.String contentType, javax.servlet.MultipartConfigElement config, java.io.File contextTmpDir)
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voiddeleteParts()Delete any tmp storage for parts, and clear out the parts list.intgetBufferSize()javax.servlet.http.PartgetPart(java.lang.String name)Get the named Part.java.util.Collection<javax.servlet.http.Part>getParts()Parse, if necessary, the multipart data and return the list of Parts.booleanisDeleteOnExit()Deprecated.no replacement providedbooleanisEmpty()Deprecated.use getParts().isEmpty()booleanisWriteFilesWithFilenames()protected voidparse()Parse, if necessary, the multipart stream.voidsetBufferSize(int bufferSize)voidsetDeleteOnExit(boolean deleteOnExit)Deprecated.no replacement provided.voidsetWriteFilesWithFilenames(boolean writeFilesWithFilenames)protected voidthrowIfError()Throws an exception if one has been latched.
-
-
-
Constructor Detail
-
MultiPartFormInputStream
public MultiPartFormInputStream(java.io.InputStream in, java.lang.String contentType, javax.servlet.MultipartConfigElement config, java.io.File contextTmpDir)- Parameters:
in- Request input streamcontentType- Content-Type headerconfig- MultipartConfigElementcontextTmpDir- javax.servlet.context.tempdir
-
-
Method Detail
-
isEmpty
@Deprecated public boolean isEmpty()
Deprecated.use getParts().isEmpty()- Returns:
- whether the list of parsed parts is empty
-
deleteParts
public void deleteParts()
Delete any tmp storage for parts, and clear out the parts list.
-
getParts
public java.util.Collection<javax.servlet.http.Part> getParts() throws java.io.IOExceptionParse, if necessary, the multipart data and return the list of Parts.- Returns:
- the parts
- Throws:
java.io.IOException- if unable to get the parts
-
getPart
public javax.servlet.http.Part getPart(java.lang.String name) throws java.io.IOExceptionGet the named Part.- Parameters:
name- the part name- Returns:
- the parts
- Throws:
java.io.IOException- if unable to get the part
-
throwIfError
protected void throwIfError() throws java.io.IOExceptionThrows an exception if one has been latched.- Throws:
java.io.IOException- the exception (if present)
-
parse
protected void parse()
Parse, if necessary, the multipart stream.
-
setDeleteOnExit
@Deprecated public void setDeleteOnExit(boolean deleteOnExit)
Deprecated.no replacement provided.
-
setWriteFilesWithFilenames
public void setWriteFilesWithFilenames(boolean writeFilesWithFilenames)
-
isWriteFilesWithFilenames
public boolean isWriteFilesWithFilenames()
-
isDeleteOnExit
@Deprecated public boolean isDeleteOnExit()
Deprecated.no replacement provided
-
getBufferSize
public int getBufferSize()
- Returns:
- the size of buffer used to read data from the input stream
-
setBufferSize
public void setBufferSize(int bufferSize)
- Parameters:
bufferSize- the size of buffer used to read data from the input stream
-
-