org.apache.commons.fileupload上传临时文件删除方法2则

简介: 在将文件项封装成FileItem 对象时,如果文件尺寸大于临界值,将会被写入临时文件。 清理方法1这些临时文件在不再被使用的时候(如果相应的java.io.File是可回收的则更好)会自动被删除.这会被org.apache.commons.io.FileCleaningTracker的一个实例启动的一个收割线程默默执行.    在一个web应用中,资源清理是被javax.servlet

在将文件项封装成FileItem 对象时,如果文件尺寸大于临界值,将会被写入临时文件。

 

  • 清理方法1

这些临时文件在不再被使用的时候(如果相应的java.io.File是可回收的则更好)会自动被删除.这会被org.apache.commons.io.FileCleaningTracker的一个实例启动的一个收割线程默默执行.

    在一个web应用中,资源清理是被javax.servlet.ServletContextListener的一个实例控制的.在其他环境中,类似的观念定是适用的.

     FileCleanerCleanup

      web应用应该使用org.apache.commons.fileupload.FileCleanerCleanup的一个实例,只要把它 web.xml 中:

     <web-app>
       ...
       <listener>
         <listener-class>
           org.apache.commons.fileupload.servlet.FileCleanerCleanup
         </listener-class>
       </listener>
       ...
     </web-app>

不幸的是,事情到这里还没完。如果你和下面的情况一样,那么你就只需要按照上面的做,就可以清除资源了。
你使用的是commons-io 1.3或者更晚的版本。
你是从web应用的web-inf/lib里载入commons-io的,并不是从其它位置,如Tomcatcommon/lib下。
如果commons-io 1.3是从你的WEB容器的classpath里载入的,那么,下面的情况可能会出现:
建议你运行两个应用,一个叫A,一个叫B。(这两个应用可能是完全一样,只不过上下文名称不一样。)这两个应用都使用了FileCleanerCleanup。现在,如果你终止应用AB还在运行,这时,A会终止B的收割机线程。换言之,你要十分仔细地考虑是使用FileCleanerCleanup,还是不使用。    

  • 清理方法2

 创建一个 DiskFileItemFactory

      FileCleanerCleanup 提供一个 org.apache.commons.io.FileCleaningTracker 实例.此实例必须在创建一个 org.apache.commons.fileupload.disk.DiskFileItemFactory 时使用.这应该通过调用如下方法来实现:

 

FileCleaningTracker fileCleaningTracker = FileCleanerCleanup.getFileCleaningTracker(servletcontext);

 

DiskFileItemFactory factory = new DiskFileItemFactory();

 

factory.setFileCleaningTracker(fileCleaningTracker);

 

 FileCleanerCleanup 通过一个静态方法getFileCleaningTracker()提供一个
org.apache.commons.io.FileCleaningTracker 对象。构造DiskFileItemFactory后,需要设置一个 
FileCleaningTracker 对象,用于追踪产生的临时文件。如果不想追踪临时文件,设置 
FileCleaningTracker 为null。

相关文章
|
4月前
|
消息中间件 Kafka Apache
Apache Flink消费Kafka数据时,可以通过设置`StreamTask.setInvokingTaskNumber`方法来实现限流
Apache Flink消费Kafka数据时,可以通过设置`StreamTask.setInvokingTaskNumber`方法来实现限流
75 1
|
Apache
给Apache虚拟主机增加端口的方法
给Apache虚拟主机增加端口的方法
105 0
|
云安全 消息中间件 监控
Apache Log4j2 高危漏洞应急响应处置方法汇总整理
Apache Log4j2 高危漏洞应急响应处置方法汇总整理
486 0
Apache Log4j2 高危漏洞应急响应处置方法汇总整理
|
Apache
org.apache.commons.lang.StringUtils的常用方法
org.apache.commons.lang.StringUtils的常用方法
882 0
Apache httpclient的execute方法调试
Apache httpclient的execute方法调试
Apache httpclient的execute方法调试
|
Apache
Apache httpclient的execute方法调试
Apache httpclient的execute方法调试
115 0
Apache httpclient的execute方法调试
|
关系型数据库 MySQL Linux
在CentOS上安装搭建PHP+Apache+Mysql的服务器环境方法
本篇给大家分享一下在CentOS上安装搭建PHP+Apache+Mysql的服务器环境方法,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。
|
Web App开发 测试技术 Linux
centos下安装与配置Apache方法
下面以httpd-2.0.55.tar.gz版本为例,介绍Apache在Linux中的安装过程:1、解压和解包安装文件:gzip -d httpd-2.0.55.tar.gztar xvf httpd-2.0.55.tar2、配置:cd httpd-2.0.55./configure --prefix=/usr3、编译:make4、安装:make install5、配置:vi /usr/conf/httpd.conf将文件中“#ServerName www.example.com:80”这一行中的“#”删掉,并将www.example.com 改为linux本机的IP地址。
881 0
|
关系型数据库 MySQL Linux
Linux下将Mysql和Apache加入到系统服务里的方法
Apache加入到系统服务里面:   cp /安装目录下/apache/bin/apachectl /etc/rc.d/init.d/httpd   修改httpd   在文件头部加入如下内容:   ###   # Comments to support chkconfig on RedHat Li...
671 0

热门文章

最新文章

推荐镜像

更多