public abstract class FileUploadBase extends 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.SizeException
This exception is thrown, if a requests permitted size
is exceeded.
|
static class |
FileUploadBase.SizeLimitExceededException
Thrown to indicate that the request size exceeds the configured maximum.
|
Modifier and Type | Field and Description |
---|---|
static String |
ATTACHMENT
Content-disposition value for file attachment.
|
static String |
CONTENT_DISPOSITION
HTTP content disposition header name.
|
static String |
CONTENT_LENGTH
HTTP content length header name.
|
static String |
CONTENT_TYPE
HTTP content type header name.
|
static String |
FORM_DATA
Content-disposition value for form data.
|
static String |
MULTIPART
Part of HTTP content type header.
|
static String |
MULTIPART_FORM_DATA
HTTP content type header for multipart forms.
|
static String |
MULTIPART_MIXED
HTTP content type header for multiple uploads.
|
Constructor and Description |
---|
FileUploadBase() |
Modifier and Type | Method and Description |
---|---|
protected byte[] |
getBoundary(String contentType)
Retrieves the boundary from the
Content-type header. |
protected String |
getFieldName(FileItemHeaders headers)
Retrieves the field name from the
Content-disposition
header. |
abstract FileItemFactory |
getFileItemFactory()
Returns the factory class used when creating file items.
|
protected String |
getFileName(FileItemHeaders headers)
Retrieves the file name from the
Content-disposition
header. |
long |
getFileSizeMax()
Returns the maximum allowed size of a single uploaded file,
as opposed to
getSizeMax() . |
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. |
protected FileItemHeaders |
getParsedHeaders(String headerPart)
Parses the
header-part and returns as key/value
pairs. |
ProgressListener |
getProgressListener()
Returns the progress listener.
|
long |
getSizeMax()
Returns the maximum allowed size of a complete request, as opposed
to
getFileSizeMax() . |
static boolean |
isMultipartContent(RequestContext ctx)
Utility method that determines whether the request contains multipart
content.
|
protected FileItemHeadersImpl |
newFileItemHeaders()
Creates a new instance of
FileItemHeaders . |
Map<String,List<FileItem>> |
parseParameterMap(RequestContext ctx)
Processes an RFC 1867
compliant
multipart/form-data stream. |
List<FileItem> |
parseRequest(RequestContext ctx)
Processes an RFC 1867
compliant
multipart/form-data stream. |
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(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 String CONTENT_TYPE
public static final String CONTENT_DISPOSITION
public static final String CONTENT_LENGTH
public static final String FORM_DATA
public static final String ATTACHMENT
public static final String MULTIPART
public static final String MULTIPART_FORM_DATA
public static final String MULTIPART_MIXED
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.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 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(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.public FileItemIterator getItemIterator(RequestContext ctx) throws FileUploadException, 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.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 List<FileItem> parseRequest(RequestContext ctx) throws FileUploadException
multipart/form-data
stream.ctx
- The context for the 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 Map<String,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.protected byte[] getBoundary(String contentType)
Content-type
header.contentType
- The value of the content type header from which to
extract the boundary value.protected String getFileName(FileItemHeaders headers)
Content-disposition
header.headers
- The HTTP headers object.encapsulation
.protected String getFieldName(FileItemHeaders headers)
Content-disposition
header.headers
- A Map
containing the HTTP request headers.encapsulation
.protected FileItemHeaders getParsedHeaders(String headerPart)
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.
headerPart
- The header-part
of the current
encapsulation
.Map
containing the parsed HTTP request headers.protected FileItemHeadersImpl newFileItemHeaders()
FileItemHeaders
.public ProgressListener getProgressListener()
public void setProgressListener(ProgressListener pListener)
pListener
- The progress listener, if any. Defaults to null.Copyright © 2000-2014 Apache Software Foundation. All Rights Reserved.