Class DiskFileItemFactory
- All Implemented Interfaces:
- FileItemFactory
The default FileItemFactory
 implementation. This implementation creates
 FileItem instances which keep
 their
 content either in memory, for smaller items, or in a temporary file on disk,
 for larger items. The size threshold, above which content will be stored on
 disk, is configurable, as is the directory in which temporary files will be
 created.
If not otherwise configured, the default configuration values are as follows:
- Size threshold is 10 KiB.
- Repository is the system default temp directory, as returned by
       System.getProperty("java.io.tmpdir").
 NOTE: Files are created in the system default temp directory with
 predictable names. This means that a local attacker with write access to that
 directory can perform a TOUTOC attack to replace any uploaded file with a
 file of the attackers choice. The implications of this will depend on how the
 uploaded file is used but could be significant. When using this
 implementation in an environment with local, untrusted users,
 setRepository(File) MUST be used to configure a repository location
 that is not publicly writable. In a Servlet container the location identified
 by the ServletContext attribute jakarta.servlet.context.tempdir
 may be used.
 
Temporary files, which are created for file items, will be deleted when the associated request is recycled.
- Since:
- FileUpload 1.1
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intThe default threshold above which uploads will be stored on disk.
- 
Constructor SummaryConstructorsConstructorDescriptionConstructs an unconfigured instance of this class.DiskFileItemFactory(int sizeThreshold, File repository) Constructs a preconfigured instance of this class.
- 
Method SummaryModifier and TypeMethodDescriptioncreateItem(String fieldName, String contentType, boolean isFormField, String fileName) Create a newDiskFileIteminstance from the supplied parameters and the local factory configuration.Gets the default charset for use when no explicit charset parameter is provided by the sender.Gets the directory used to temporarily store files that are larger than the configured size threshold.intGets the size threshold beyond which files are written directly to disk.voidsetDefaultCharset(String charset) Sets the default charset for use when no explicit charset parameter is provided by the sender.voidsetRepository(File repository) Sets the directory used to temporarily store files that are larger than the configured size threshold.voidsetSizeThreshold(int sizeThreshold) Sets the size threshold beyond which files are written directly to disk.
- 
Field Details- 
DEFAULT_SIZE_THRESHOLDpublic static final int DEFAULT_SIZE_THRESHOLDThe default threshold above which uploads will be stored on disk.- See Also:
 
 
- 
- 
Constructor Details- 
DiskFileItemFactorypublic DiskFileItemFactory()Constructs an unconfigured instance of this class. The resulting factory may be configured by calling the appropriate setter methods.
- 
DiskFileItemFactoryConstructs a preconfigured instance of this class.- Parameters:
- sizeThreshold- The threshold, in bytes, below which items will be retained in memory and above which they will be stored as a file.
- repository- The data repository, which is the directory in which files will be created, should the item size exceed the threshold.
 
 
- 
- 
Method Details- 
createItempublic FileItem createItem(String fieldName, String contentType, boolean isFormField, String fileName) Create a newDiskFileIteminstance from the supplied parameters and the local factory configuration.- Specified by:
- createItemin interface- FileItemFactory
- Parameters:
- fieldName- The name of the form field.
- contentType- The content type of the form field.
- isFormField-- trueif this is a plain form field;- falseotherwise.
- fileName- The name of the uploaded file, if any, as supplied by the browser or other client.
- Returns:
- The newly created file item.
 
- 
getDefaultCharsetGets the default charset for use when no explicit charset parameter is provided by the sender.- Returns:
- the default charset
 
- 
getRepositoryGets the directory used to temporarily store files that are larger than the configured size threshold.- Returns:
- The directory in which temporary files will be located.
- See Also:
 
- 
getSizeThresholdpublic int getSizeThreshold()Gets the size threshold beyond which files are written directly to disk. The default value is 10240 bytes.- Returns:
- The size threshold, in bytes.
- See Also:
 
- 
setDefaultCharsetSets the default charset for use when no explicit charset parameter is provided by the sender.- Parameters:
- charset- the default charset
 
- 
setRepositorySets the directory used to temporarily store files that are larger than the configured size threshold.- Parameters:
- repository- The directory in which temporary files will be located.
- See Also:
 
- 
setSizeThresholdpublic void setSizeThreshold(int sizeThreshold) Sets the size threshold beyond which files are written directly to disk.- Parameters:
- sizeThreshold- The size threshold, in bytes.
- See Also:
 
 
-