public abstract class FileUploadBase
extends java.lang.Object
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.
Modifier and Type | Class and Description |
---|---|
static class |
FileUploadBase.FileSizeLimitExceededException
Thrown to indicate that A files size exceeds the configured maximum.
|
static class |
FileUploadBase.FileUploadIOException
This exception is thrown for hiding an inner
FileUploadException in an IOException . |
static class |
FileUploadBase.InvalidContentTypeException
Thrown to indicate that the request is not a multipart request.
|
static class |
FileUploadBase.IOFileUploadException
Thrown to indicate an IOException.
|
static class |
FileUploadBase.SizeLimitExceededException
Thrown to indicate that the request size exceeds the configured maximum.
|
static class |
FileUploadBase.UnknownSizeException
Deprecated.
1.2 As of commons-fileupload 1.2, the presence of a
content-length header is no longer required.
|
Modifier and Type | Field and Description |
---|---|
static java.lang.String |
ATTACHMENT
Content-disposition value for file attachment.
|
static java.lang.String |
CONTENT_DISPOSITION
HTTP content disposition header name.
|
static java.lang.String |
CONTENT_LENGTH
HTTP content length header name.
|
static java.lang.String |
CONTENT_TYPE
HTTP content type header name.
|
static java.lang.String |
FORM_DATA
Content-disposition value for form data.
|
static int |
MAX_HEADER_SIZE
Deprecated.
This constant is no longer used. As of commons-fileupload
1.2, the only applicable limit is the total size of a parts headers,
MultipartStream.HEADER_PART_SIZE_MAX . |
static java.lang.String |
MULTIPART
Part of HTTP content type header.
|
static java.lang.String |
MULTIPART_FORM_DATA
HTTP content type header for multipart forms.
|
static java.lang.String |
MULTIPART_MIXED
HTTP content type header for multiple uploads.
|
Constructor and Description |
---|
FileUploadBase() |
Modifier and Type | Method and Description |
---|---|
abstract FileItemFactory |
getFileItemFactory()
Returns the factory class used when creating file items.
|
long |
getFileSizeMax()
Returns the maximum allowed size of a single uploaded file,
as opposed to
getSizeMax() . |
java.lang.String |
getHeaderEncoding()
Retrieves the character encoding used when reading the headers of an
individual part.
|
FileItemIterator |
getItemIterator(RequestContext ctx)
Processes an RFC 1867
compliant
multipart/form-data stream. |
ProgressListener |
getProgressListener()
Returns the progress listener.
|
long |
getSizeMax()
Returns the maximum allowed size of a complete request, as opposed
to
getFileSizeMax() . |
static boolean |
isMultipartContent(HttpServletRequest req)
Deprecated.
1.1 Use the method on
ServletFileUpload instead. |
static boolean |
isMultipartContent(RequestContext ctx)
Utility method that determines whether the request contains multipart
content.
|
java.util.Map<java.lang.String,java.util.List<FileItem>> |
parseParameterMap(RequestContext ctx)
Processes an RFC 1867
compliant
multipart/form-data stream. |
java.util.List<FileItem> |
parseRequest(HttpServletRequest req)
Deprecated.
1.1 Use
ServletFileUpload.parseRequest(HttpServletRequest) instead. |
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 to
getSizeMax() . |
void |
setHeaderEncoding(java.lang.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
to
setFileSizeMax(long) . |
public static final java.lang.String CONTENT_TYPE
public static final java.lang.String CONTENT_DISPOSITION
public static final java.lang.String CONTENT_LENGTH
public static final java.lang.String FORM_DATA
public static final java.lang.String ATTACHMENT
public static final java.lang.String MULTIPART
public static final java.lang.String MULTIPART_FORM_DATA
public static final java.lang.String MULTIPART_MIXED
@Deprecated public static final int MAX_HEADER_SIZE
MultipartStream.HEADER_PART_SIZE_MAX
.public static final boolean isMultipartContent(RequestContext ctx)
Utility method that determines whether the request contains multipart content.
NOTE:This method will be moved to the
ServletFileUpload
class after the FileUpload 1.1 release.
Unfortunately, since this method is static, it is not possible to
provide its replacement until this method is removed.
ctx
- The request context to be evaluated. Must be non-null.true
if the request is multipart;
false
otherwise.@Deprecated public static boolean isMultipartContent(HttpServletRequest req)
ServletFileUpload
instead.req
- The servlet request to be evaluated. Must be non-null.true
if the request is multipart;
false
otherwise.public abstract FileItemFactory getFileItemFactory()
public abstract void setFileItemFactory(FileItemFactory factory)
factory
- The factory class for new file items.public long getSizeMax()
getFileSizeMax()
.setSizeMax(long)
public void setSizeMax(long sizeMax)
setFileSizeMax(long)
.sizeMax
- The maximum allowed size, in bytes. The default value of
-1 indicates, that there is no limit.getSizeMax()
public long getFileSizeMax()
getSizeMax()
.setFileSizeMax(long)
public void setFileSizeMax(long fileSizeMax)
getSizeMax()
.fileSizeMax
- Maximum size of a single uploaded file.getFileSizeMax()
public java.lang.String getHeaderEncoding()
null
, the request
encoding is used. If that is also not specified, or null
,
the platform default encoding is used.public void setHeaderEncoding(java.lang.String encoding)
null
, the request
encoding is used. If that is also not specified, or null
,
the platform default encoding is used.encoding
- The encoding used to read part headers.@Deprecated public java.util.List<FileItem> parseRequest(HttpServletRequest req) throws FileUploadException
ServletFileUpload.parseRequest(HttpServletRequest)
instead.multipart/form-data
stream.req
- The servlet request to be parsed.FileItem
instances parsed from the
request, in the order that they were transmitted.FileUploadException
- if there are problems reading/parsing
the request or storing files.public FileItemIterator getItemIterator(RequestContext ctx) throws FileUploadException, java.io.IOException
multipart/form-data
stream.ctx
- The context for the request to be parsed.FileItemStream
parsed from the request, in the order that they were
transmitted.FileUploadException
- if there are problems reading/parsing
the request or storing files.java.io.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.public java.util.Map<java.lang.String,java.util.List<FileItem>> parseParameterMap(RequestContext ctx) throws FileUploadException
multipart/form-data
stream.ctx
- The context for the request to be parsed.FileItem
instances parsed from the request.FileUploadException
- if there are problems reading/parsing
the request or storing files.public ProgressListener getProgressListener()
public void setProgressListener(ProgressListener pListener)
pListener
- The progress listener, if any. Defaults to null."Copyright © 2010 - 2020 Adobe Systems Incorporated. All Rights Reserved"