Class FileUploadBase
java.lang.Object
org.apache.tomcat.util.http.fileupload.FileUploadBase
- Direct Known Subclasses:
FileUpload
High level API for processing file uploads.
This class handles multiple files per single HTML widget, sent using
multipart/mixed
encoding type, as specified by
RFC 1867. Use parseRequest(RequestContext)
to acquire a list of FileItem
s associated with a given HTML
widget.
How the data for individual parts is stored is determined by the factory used to create them; a given part may be in memory, on disk, or somewhere else.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
Content-disposition value for file attachment.static final String
HTTP content disposition header name.static final String
HTTP content length header name.static final String
HTTP content type header name.static final String
Content-disposition value for form data.static final String
Part of HTTP content type header.static final String
HTTP content type header for multipart forms.static final String
HTTP content type header for multiple uploads. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionbyte[]
getBoundary
(String contentType) Retrieves the boundary from theContent-type
header.getFieldName
(FileItemHeaders headers) Retrieves the field name from theContent-disposition
header.long
Returns the maximum number of files allowed in a single request.abstract FileItemFactory
Returns the factory class used when creating file items.getFileName
(FileItemHeaders headers) Retrieves the file name from theContent-disposition
header.long
Returns the maximum allowed size of a single uploaded file, as opposed togetSizeMax()
.Retrieves the character encoding used when reading the headers of an individual part.Processes an RFC 1867 compliantmultipart/form-data
stream.getParsedHeaders
(String headerPart) Parses theheader-part
and returns as key/value pairs.Returns the progress listener.long
Returns the maximum allowed size of a complete request, as opposed togetFileSizeMax()
.protected FileItemHeadersImpl
Creates a new instance ofFileItemHeaders
.Processes an RFC 1867 compliantmultipart/form-data
stream.void
setFileCountMax
(long fileCountMax) Sets the maximum number of files allowed per request.abstract void
setFileItemFactory
(FileItemFactory factory) Sets the factory class to use when creating file items.void
setFileSizeMax
(long fileSizeMax) Sets the maximum allowed size of a single uploaded file, as opposed togetSizeMax()
.void
setHeaderEncoding
(String encoding) Specifies the character encoding to be used when reading the headers of individual part.void
setProgressListener
(ProgressListener pListener) Sets the progress listener.void
setSizeMax
(long sizeMax) Sets the maximum allowed size of a complete request, as opposed tosetFileSizeMax(long)
.
-
Field Details
-
CONTENT_TYPE
HTTP content type header name.- See Also:
-
CONTENT_DISPOSITION
HTTP content disposition header name.- See Also:
-
CONTENT_LENGTH
HTTP content length header name.- See Also:
-
FORM_DATA
Content-disposition value for form data.- See Also:
-
ATTACHMENT
Content-disposition value for file attachment.- See Also:
-
MULTIPART
Part of HTTP content type header.- See Also:
-
MULTIPART_FORM_DATA
HTTP content type header for multipart forms.- See Also:
-
MULTIPART_MIXED
HTTP content type header for multiple uploads.- See Also:
-
-
Constructor Details
-
FileUploadBase
public FileUploadBase()
-
-
Method Details
-
getFileItemFactory
Returns the factory class used when creating file items.- Returns:
- The factory class for new file items.
-
setFileItemFactory
Sets the factory class to use when creating file items.- Parameters:
factory
- The factory class for new file items.
-
getSizeMax
public long getSizeMax()Returns the maximum allowed size of a complete request, as opposed togetFileSizeMax()
.- Returns:
- The maximum allowed size, in bytes. The default value of -1 indicates, that there is no limit.
- See Also:
-
setSizeMax
public void setSizeMax(long sizeMax) Sets the maximum allowed size of a complete request, as opposed tosetFileSizeMax(long)
.- Parameters:
sizeMax
- The maximum allowed size, in bytes. The default value of -1 indicates, that there is no limit.- See Also:
-
getFileSizeMax
public long getFileSizeMax()Returns the maximum allowed size of a single uploaded file, as opposed togetSizeMax()
.- Returns:
- Maximum size of a single uploaded file.
- See Also:
-
setFileSizeMax
public void setFileSizeMax(long fileSizeMax) Sets the maximum allowed size of a single uploaded file, as opposed togetSizeMax()
.- Parameters:
fileSizeMax
- Maximum size of a single uploaded file.- See Also:
-
getFileCountMax
public long getFileCountMax()Returns the maximum number of files allowed in a single request.- Returns:
- The maximum number of files allowed in a single request.
-
setFileCountMax
public void setFileCountMax(long fileCountMax) Sets the maximum number of files allowed per request.- Parameters:
fileCountMax
- The new limit.-1
means no limit.
-
getHeaderEncoding
Retrieves the character encoding used when reading the headers of an individual part. When not specified, ornull
, the request encoding is used. If that is also not specified, ornull
, the platform default encoding is used.- Returns:
- The encoding used to read part headers.
-
setHeaderEncoding
Specifies the character encoding to be used when reading the headers of individual part. When not specified, ornull
, the request encoding is used. If that is also not specified, ornull
, the platform default encoding is used.- Parameters:
encoding
- The encoding used to read part headers.
-
getItemIterator
Processes an RFC 1867 compliantmultipart/form-data
stream.- Parameters:
ctx
- The context for the request to be parsed.- Returns:
- An iterator to instances of
FileItemStream
parsed from the request, in the order that they were transmitted. - Throws:
FileUploadException
- if there are problems reading/parsing the request or storing files.IOException
- An I/O error occurred. This may be a network error while communicating with the client or a problem while storing the uploaded content.
-
parseRequest
Processes an RFC 1867 compliantmultipart/form-data
stream.- Parameters:
ctx
- The context for the request to be parsed.- Returns:
- A list of
FileItem
instances parsed from the request, in the order that they were transmitted. - Throws:
FileUploadException
- if there are problems reading/parsing the request or storing files.
-
getBoundary
Retrieves the boundary from theContent-type
header.- Parameters:
contentType
- The value of the content type header from which to extract the boundary value.- Returns:
- The boundary, as a byte array.
-
getFileName
Retrieves the file name from theContent-disposition
header.- Parameters:
headers
- The HTTP headers object.- Returns:
- The file name for the current
encapsulation
.
-
getFieldName
Retrieves the field name from theContent-disposition
header.- Parameters:
headers
- AMap
containing the HTTP request headers.- Returns:
- The field name for the current
encapsulation
.
-
getParsedHeaders
Parses the
header-part
and returns as key/value pairs.If there are multiple headers of the same names, the name will map to a comma-separated list containing the values.
- Parameters:
headerPart
- Theheader-part
of the currentencapsulation
.- Returns:
- A
Map
containing the parsed HTTP request headers.
-
newFileItemHeaders
Creates a new instance ofFileItemHeaders
.- Returns:
- The new instance.
-
getProgressListener
Returns the progress listener.- Returns:
- The progress listener, if any, or null.
-
setProgressListener
Sets the progress listener.- Parameters:
pListener
- The progress listener, if any. Defaults to null.
-