Class FileUploadBase
- java.lang.Object
-
- org.apache.commons.fileupload.FileUploadBase
-
- Direct Known Subclasses:
DiskFileUpload,FileUpload
public abstract class FileUploadBase extends java.lang.ObjectHigh level API for processing file uploads.
This class handles multiple files per single HTML widget, sent using
multipart/mixedencoding type, as specified by RFC 1867. UseparseRequest(HttpServletRequest)to acquire a list ofFileItems 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.
- Version:
- $Id: FileUploadBase.java 367087 2006-01-08 20:19:37Z martinc $
- Author:
- Rafal Krzewski, Daniel Rall, Jason van Zyl, John McNally, Martin Cooper, Sean C. Sullivan
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classFileUploadBase.InvalidContentTypeExceptionThrown to indicate that the request is not a multipart request.static classFileUploadBase.SizeLimitExceededExceptionThrown to indicate that the request size exceeds the configured maximum.static classFileUploadBase.UnknownSizeExceptionThrown to indicate that the request size is not specified.
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringATTACHMENTContent-disposition value for file attachment.static java.lang.StringCONTENT_DISPOSITIONHTTP content disposition header name.static java.lang.StringCONTENT_TYPEHTTP content type header name.static java.lang.StringFORM_DATAContent-disposition value for form data.private java.lang.StringheaderEncodingThe content encoding to use when reading part headers.static intMAX_HEADER_SIZEThe maximum length of a single header line that will be parsed (1024 bytes).private MultipartStreammultistatic java.lang.StringMULTIPARTPart of HTTP content type header.static java.lang.StringMULTIPART_FORM_DATAHTTP content type header for multipart forms.static java.lang.StringMULTIPART_MIXEDHTTP content type header for multiple uploads.private longsizeMaxThe maximum size permitted for an uploaded file.
-
Constructor Summary
Constructors Constructor Description FileUploadBase()
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected FileItemcreateItem(java.util.Map headers, boolean isFormField)Creates a newFileIteminstance.protected byte[]getBoundary(java.lang.String contentType)Retrieves the boundary from theContent-typeheader.protected java.lang.StringgetFieldName(java.util.Map headers)Retrieves the field name from theContent-dispositionheader.abstract FileItemFactorygetFileItemFactory()Returns the factory class used when creating file items.protected java.lang.StringgetFileName(java.util.Map headers)Retrieves the file name from theContent-dispositionheader.protected java.lang.StringgetHeader(java.util.Map headers, java.lang.String name)Returns the header with the specified name from the supplied map.java.lang.StringgetHeaderEncoding()Retrieves the character encoding used when reading the headers of an individual part.longgetSizeMax()Returns the maximum allowed upload size.static booleanisMultipartContent(javax.servlet.http.HttpServletRequest req)Deprecated.Use the method onServletFileUploadinstead.static booleanisMultipartContent(RequestContext ctx)Utility method that determines whether the request contains multipart content.protected java.util.MapparseHeaders(java.lang.String headerPart)Parses theheader-partand returns as key/value pairs.java.util.ListparseRequest(javax.servlet.http.HttpServletRequest req)Deprecated.Use the method inServletFileUploadinstead.java.util.ListparseRequest(RequestContext ctx)Processes an RFC 1867 compliantmultipart/form-datastream.abstract voidsetFileItemFactory(FileItemFactory factory)Sets the factory class to use when creating file items.voidsetHeaderEncoding(java.lang.String encoding)Specifies the character encoding to be used when reading the headers of individual part.voidsetSizeMax(long sizeMax)Sets the maximum allowed upload size.
-
-
-
Field Detail
-
CONTENT_TYPE
public static final java.lang.String CONTENT_TYPE
HTTP content type header name.- See Also:
- Constant Field Values
-
CONTENT_DISPOSITION
public static final java.lang.String CONTENT_DISPOSITION
HTTP content disposition header name.- See Also:
- Constant Field Values
-
FORM_DATA
public static final java.lang.String FORM_DATA
Content-disposition value for form data.- See Also:
- Constant Field Values
-
ATTACHMENT
public static final java.lang.String ATTACHMENT
Content-disposition value for file attachment.- See Also:
- Constant Field Values
-
MULTIPART
public static final java.lang.String MULTIPART
Part of HTTP content type header.- See Also:
- Constant Field Values
-
MULTIPART_FORM_DATA
public static final java.lang.String MULTIPART_FORM_DATA
HTTP content type header for multipart forms.- See Also:
- Constant Field Values
-
MULTIPART_MIXED
public static final java.lang.String MULTIPART_MIXED
HTTP content type header for multiple uploads.- See Also:
- Constant Field Values
-
MAX_HEADER_SIZE
public static final int MAX_HEADER_SIZE
The maximum length of a single header line that will be parsed (1024 bytes).- See Also:
- Constant Field Values
-
multi
private MultipartStream multi
-
sizeMax
private long sizeMax
The maximum size permitted for an uploaded file. A value of -1 indicates no maximum.
-
headerEncoding
private java.lang.String headerEncoding
The content encoding to use when reading part headers.
-
-
Method Detail
-
isMultipartContent
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
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.
-
isMultipartContent
public static final boolean isMultipartContent(javax.servlet.http.HttpServletRequest req)
Deprecated.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.
-
getFileItemFactory
public abstract FileItemFactory getFileItemFactory()
Returns the factory class used when creating file items.- Returns:
- The factory class for new file items.
-
setFileItemFactory
public abstract void setFileItemFactory(FileItemFactory factory)
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 upload size.- Returns:
- The maximum allowed size, in bytes.
- See Also:
setSizeMax(long)
-
setSizeMax
public void setSizeMax(long sizeMax)
Sets the maximum allowed upload size. If negative, there is no maximum.- Parameters:
sizeMax- The maximum allowed size, in bytes, or -1 for no maximum.- See Also:
getSizeMax()
-
getHeaderEncoding
public java.lang.String 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
public void setHeaderEncoding(java.lang.String encoding)
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.
-
parseRequest
public java.util.List parseRequest(javax.servlet.http.HttpServletRequest req) throws FileUploadExceptionDeprecated.Use the method inServletFileUploadinstead.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.
-
parseRequest
public java.util.List parseRequest(RequestContext ctx) throws FileUploadException
Processes 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.
-
getBoundary
protected byte[] getBoundary(java.lang.String contentType)
Retrieves 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.
-
getFileName
protected java.lang.String getFileName(java.util.Map headers)
Retrieves the file name from theContent-dispositionheader.- Parameters:
headers- AMapcontaining the HTTP request headers.- Returns:
- The file name for the current
encapsulation.
-
getFieldName
protected java.lang.String getFieldName(java.util.Map headers)
Retrieves the field name from theContent-dispositionheader.- Parameters:
headers- AMapcontaining the HTTP request headers.- Returns:
- The field name for the current
encapsulation.
-
createItem
protected FileItem createItem(java.util.Map headers, boolean isFormField) throws FileUploadException
Creates a newFileIteminstance.- Parameters:
headers- AMapcontaining the HTTP request headers.isFormField- Whether or not this item is a form field, as opposed to a file.- Returns:
- A newly created
FileIteminstance. - Throws:
FileUploadException- if an error occurs.
-
parseHeaders
protected java.util.Map parseHeaders(java.lang.String headerPart)
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- Theheader-partof the currentencapsulation.- Returns:
- A
Mapcontaining the parsed HTTP request headers.
-
getHeader
protected final java.lang.String getHeader(java.util.Map headers, java.lang.String name)Returns the header with the specified name from the supplied map. The header lookup is case-insensitive.- Parameters:
headers- AMapcontaining 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.
-
-