Class FileUploadBase
- Direct Known Subclasses:
- DiskFileUpload,- FileUpload
 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
 FileItems 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.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classThrown to indicate that A files size exceeds the configured maximum.static classSignals that a FileUpload I/O exception of some sort has occurred.static classThrown to indicate that the request is not a multipart request.static classThrown to indicate an IOException.protected static classThis exception is thrown, if a requests permitted size is exceeded.static classThrown to indicate that the request size exceeds the configured maximum.static classDeprecated.1.2 As of commons-fileupload 1.2, the presence of a content-length header is no longer required.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringContent-disposition value for file attachment.static final StringHTTP content disposition header name.static final StringHTTP content length header name.static final StringHTTP content type header name.static final intDefault per part header size limit in bytes.static final StringContent-disposition value for form data.static final intDeprecated.This constant is no longer used.static final StringPart of HTTP content type header.static final StringHTTP content type header for multipart forms.static final StringHTTP content type header for multiple uploads.static final StringHTTP content type header for multiple related data.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected FileItemcreateItem(Map<String, String> headers, boolean isFormField) Deprecated.1.2 This method is no longer used in favor of internally created instances ofFileItem.protected byte[]getBoundary(String contentType) Gets the boundary from theContent-typeheader.protected StringgetFieldName(Map<String, String> headers) Deprecated.1.2.1 UsegetFieldName(FileItemHeaders).protected StringgetFieldName(FileItemHeaders headers) Gets the field name from theContent-dispositionheader.longReturns the maximum number of files allowed in a single request.abstract FileItemFactoryReturns the factory class used when creating file items.protected StringgetFileName(Map<String, String> headers) Deprecated.1.2.1 UsegetFileName(FileItemHeaders).protected StringgetFileName(FileItemHeaders headers) Gets the file name from theContent-dispositionheader.longReturns the maximum allowed size of a single uploaded file, as opposed togetSizeMax().protected final StringDeprecated.1.2.1 UseFileItemHeaders.getHeader(String).Gets the character encoding used when reading the headers of an individual part.Processes an RFC 1867 compliantmultipart/form-datastream.protected FileItemHeadersgetParsedHeaders(String headerPart) Parses theheader-partand returns as key/value pairs.intObtain the per part size limit for headers.Returns the progress listener.longReturns the maximum allowed size of a complete request, as opposed togetFileSizeMax().static booleanDeprecated.1.1 Use the method onServletFileUploadinstead.static final booleanUtility method that determines whether the request contains multipart content.protected FileItemHeadersImplCreates a new instance ofFileItemHeaders.parseHeaders(String headerPart) Deprecated.1.2.1 UsegetParsedHeaders(String)Processes an RFC 1867 compliantmultipart/form-datastream.Deprecated.1.1 UseServletFileUpload.parseRequest(HttpServletRequest)instead.Processes an RFC 1867 compliantmultipart/form-datastream.voidsetFileCountMax(long fileCountMax) Sets the maximum number of files allowed per request.abstract voidsetFileItemFactory(FileItemFactory factory) Sets the factory class to use when creating file items.voidsetFileSizeMax(long fileSizeMax) Sets the maximum allowed size of a single uploaded file, as opposed togetSizeMax().voidsetHeaderEncoding(String encoding) Specifies the character encoding to be used when reading the headers of individual part.voidsetPartHeaderSizeMax(int partHeaderSizeMax) Sets the per part size limit for headers.voidsetProgressListener(ProgressListener listener) Sets the progress listener.voidsetSizeMax(long sizeMax) Sets the maximum allowed size of a complete request, as opposed tosetFileSizeMax(long).
- 
Field Details- 
CONTENT_TYPEHTTP content type header name.- See Also:
 
- 
CONTENT_DISPOSITIONHTTP content disposition header name.- See Also:
 
- 
CONTENT_LENGTHHTTP content length header name.- See Also:
 
- 
FORM_DATAContent-disposition value for form data.- See Also:
 
- 
ATTACHMENTContent-disposition value for file attachment.- See Also:
 
- 
MULTIPARTPart of HTTP content type header.- See Also:
 
- 
MULTIPART_FORM_DATAHTTP content type header for multipart forms.- See Also:
 
- 
MULTIPART_MIXEDHTTP content type header for multiple uploads.- See Also:
 
- 
MULTIPART_RELATEDHTTP content type header for multiple related data.- Since:
- 1.6.0
- See Also:
 
- 
MAX_HEADER_SIZEDeprecated.This constant is no longer used. As of commons-fileupload 1.6, the applicable limit is the total size of a single part's headers,getPartHeaderSizeMax()in bytes.The maximum length of a single header line that will be parsed (1024 bytes).- See Also:
 
- 
DEFAULT_PART_HEADER_SIZE_MAXDefault per part header size limit in bytes.- Since:
- 1.6.0
- See Also:
 
 
- 
- 
Constructor Details- 
FileUploadBasepublic FileUploadBase()Constructs a new instance.
 
- 
- 
Method Details- 
isMultipartContentDeprecated.1.1 Use the method onServletFileUploadinstead.Utility method that determines whether the request contains multipart content.- Parameters:
- req- The servlet request to be evaluated. Must be non-null.
- Returns:
- trueif the request is multipart;- falseotherwise.
 
- 
isMultipartContentUtility method that determines whether the request contains multipart content. NOTE:This method will be moved to the ServletFileUploadclass 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.- Parameters:
- ctx- The request context to be evaluated. Must be non-null.
- Returns:
- trueif the request is multipart;- falseotherwise.
 
- 
createItemDeprecated.1.2 This method is no longer used in favor of internally created instances ofFileItem.Creates a newFileIteminstance.- Parameters:
- headers- A- Mapcontaining the HTTP request headers.
- isFormField- Whether or not this item is a form field, as opposed to a file.
- Returns:
- A newly created FileIteminstance.
 
- 
getBoundaryGets the boundary from theContent-typeheader.- Parameters:
- contentType- The value of the content type header from which to extract the boundary value.
- Returns:
- The boundary, as a byte array.
 
- 
getFieldNameGets the field name from theContent-dispositionheader.- Parameters:
- headers- A- Mapcontaining the HTTP request headers.
- Returns:
- The field name for the current encapsulation.
 
- 
getFieldNameDeprecated.1.2.1 UsegetFieldName(FileItemHeaders).Gets the field name from theContent-dispositionheader.- Parameters:
- headers- A- Mapcontaining the HTTP request headers.
- Returns:
- The field name for the current encapsulation.
 
- 
getFileCountMaxReturns the maximum number of files allowed in a single request.- Returns:
- The maximum number of files allowed in a single request.
 
- 
getFileItemFactoryReturns the factory class used when creating file items.- Returns:
- The factory class for new file items.
 
- 
getFileNameGets the file name from theContent-dispositionheader.- Parameters:
- headers- The HTTP headers object.
- Returns:
- The file name for the current encapsulation.
 
- 
getFileNameDeprecated.1.2.1 UsegetFileName(FileItemHeaders).Gets the file name from theContent-dispositionheader.- Parameters:
- headers- A- Mapcontaining the HTTP request headers.
- Returns:
- The file name for the current encapsulation.
 
- 
getFileSizeMaxReturns the maximum allowed size of a single uploaded file, as opposed togetSizeMax().- Returns:
- Maximum size of a single uploaded file.
- See Also:
 
- 
getHeaderDeprecated.1.2.1 UseFileItemHeaders.getHeader(String).Returns the header with the specified name from the supplied map. The header lookup is case-insensitive.- Parameters:
- headers- A- Mapcontaining the HTTP request headers.
- name- The name of the header to return.
- Returns:
- The value of specified header, or a comma-separated list if there were multiple headers of that name.
 
- 
getHeaderEncodingGets 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.
 
- 
getItemIteratorProcesses an RFC 1867 compliantmultipart/form-datastream.- Parameters:
- ctx- The context for the request to be parsed.
- Returns:
- An iterator to instances of FileItemStreamparsed 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.
 
- 
getParsedHeadersParses the header-partand 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- The- header-partof the current- encapsulation.
- Returns:
- A Mapcontaining the parsed HTTP request headers.
 
- 
getPartHeaderSizeMaxObtain the per part size limit for headers.- Returns:
- The maximum size of the headers for a single part in bytes.
- Since:
- 1.6.0
 
- 
getProgressListenerReturns the progress listener.- Returns:
- The progress listener, if any, or null.
 
- 
getSizeMaxReturns 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:
 
- 
newFileItemHeadersCreates a new instance ofFileItemHeaders.- Returns:
- The new instance.
 
- 
parseHeadersDeprecated.1.2.1 UsegetParsedHeaders(String)Parses the header-partand 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- The- header-partof the current- encapsulation.
- Returns:
- A Mapcontaining the parsed HTTP request headers.
 
- 
parseParameterMapProcesses an RFC 1867 compliantmultipart/form-datastream.- Parameters:
- ctx- The context for the request to be parsed.
- Returns:
- A map of FileIteminstances parsed from the request.
- Throws:
- FileUploadException- if there are problems reading/parsing the request or storing files.
- Since:
- 1.3
 
- 
parseRequestDeprecated.1.1 UseServletFileUpload.parseRequest(HttpServletRequest)instead.Processes an RFC 1867 compliantmultipart/form-datastream.- Parameters:
- req- The servlet request to be parsed.
- Returns:
- A list of FileIteminstances parsed from the request, in the order that they were transmitted.
- Throws:
- FileUploadException- if there are problems reading/parsing the request or storing files.
 
- 
parseRequestProcesses an RFC 1867 compliantmultipart/form-datastream.- Parameters:
- ctx- The context for the request to be parsed.
- Returns:
- A list of FileIteminstances parsed from the request, in the order that they were transmitted.
- Throws:
- FileUploadException- if there are problems reading/parsing the request or storing files.
 
- 
setFileCountMaxSets the maximum number of files allowed per request.- Parameters:
- fileCountMax- The new limit.- -1means no limit.
 
- 
setFileItemFactorySets the factory class to use when creating file items.- Parameters:
- factory- The factory class for new file items.
 
- 
setFileSizeMaxSets the maximum allowed size of a single uploaded file, as opposed togetSizeMax().- Parameters:
- fileSizeMax- Maximum size of a single uploaded file.
- See Also:
 
- 
setHeaderEncodingSpecifies 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.
 
- 
setPartHeaderSizeMaxSets the per part size limit for headers.- Parameters:
- partHeaderSizeMax- The maximum size of the headers in bytes.
- Since:
- 1.6.0
 
- 
setProgressListenerSets the progress listener.- Parameters:
- listener- The progress listener, if any. Defaults to null.
 
- 
setSizeMaxSets 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:
 
 
-