Package org.eclipse.jetty.server
Class MultiPartFormInputStream
java.lang.Object
org.eclipse.jetty.server.MultiPartFormInputStream
MultiPartInputStream
Handle 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:
-
Nested Class Summary
-
Constructor Summary
ConstructorDescriptionMultiPartFormInputStream
(InputStream in, String contentType, jakarta.servlet.MultipartConfigElement config, File contextTmpDir) MultiPartFormInputStream
(InputStream in, String contentType, jakarta.servlet.MultipartConfigElement config, File contextTmpDir, int maxParts) -
Method Summary
Modifier and TypeMethodDescriptionvoid
Delete any tmp storage for parts, and clear out the parts list.int
jakarta.servlet.http.Part
Get the named Part.Collection<jakarta.servlet.http.Part>
getParts()
Parse, if necessary, the multipart data and return the list of Parts.boolean
Deprecated.no replacement providedboolean
isEmpty()
Deprecated.use getParts().isEmpty()boolean
protected void
parse()
Parse, if necessary, the multipart stream.void
setBufferSize
(int bufferSize) void
setDeleteOnExit
(boolean deleteOnExit) Deprecated.no replacement provided.void
setWriteFilesWithFilenames
(boolean writeFilesWithFilenames) protected void
Throws an exception if one has been latched.
-
Constructor Details
-
MultiPartFormInputStream
public MultiPartFormInputStream(InputStream in, String contentType, jakarta.servlet.MultipartConfigElement config, File contextTmpDir) - Parameters:
in
- Request input streamcontentType
- Content-Type headerconfig
- MultipartConfigElementcontextTmpDir
- "jakarta.servlet.context.tempdir"
-
MultiPartFormInputStream
public MultiPartFormInputStream(InputStream in, String contentType, jakarta.servlet.MultipartConfigElement config, File contextTmpDir, int maxParts) - Parameters:
in
- Request input streamcontentType
- Content-Type headerconfig
- MultipartConfigElementcontextTmpDir
- "jakarta.servlet.context.tempdir"maxParts
- the maximum number of parts that can be parsed from the multipart content (0 for no parts allowed, -1 for unlimited parts).
-
-
Method Details
-
getNonComplianceWarnings
- Returns:
- an EnumSet of non compliances with the RFC that were accepted by this parser
-
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
Parse, if necessary, the multipart data and return the list of Parts.- Returns:
- the parts
- Throws:
IOException
- if unable to get the parts
-
getPart
Get the named Part.- Parameters:
name
- the part name- Returns:
- the parts
- Throws:
IOException
- if unable to get the part
-
throwIfError
Throws an exception if one has been latched.- Throws:
IOException
- the exception (if present)
-
parse
protected void parse()Parse, if necessary, the multipart stream. -
setDeleteOnExit
Deprecated.no replacement provided. -
setWriteFilesWithFilenames
public void setWriteFilesWithFilenames(boolean writeFilesWithFilenames) -
isWriteFilesWithFilenames
public boolean isWriteFilesWithFilenames() -
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
-