spring boot 上传文件出错:java.io.IOException: The temporary upload location
2018-01-12 10:55
645 查看
现象:
上传excel,出现报错:
[Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid] with root causejava.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid
原因:
1.spring boot的应用服务在启动的时候,会生成在操作系统的/tmp目录下生成一个Tomcat.*的文件目录,用于"java.io.tmpdir"文件流操作
2.程序对文件的操作时:会生成临时文件,暂存在临时文件中;
lunix 系统的tmpwatch 命令会删除10天未使用的临时文件;
长时间不操作,导致/tmp下面的tomcat临时文件目录被删除,且删除的文件不可恢复,上传文件时获取不到文件目录,报错
解决方案:
1.重启服务,临时方案:会重新生成tomcat目录,但是生产环境不建议如此操作;
2.1增加服务配置,自定义baseDir:
2.2启动时增加参数-Djava.io.tmpdir=自定义目录
3.修改tmpwatch 删除文件的逻辑,系统级别的命令,不建议操作
4.在网上看到有:编码的方式catch异常,生成删除的文件夹;(方法未验证)
参考:
https://github.com/spring-projects/spring-boot/issues/5009
https://github.com/spring-projects/spring-boot/issues/9616
上传excel,出现报错:
[Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid] with root causejava.io
.IOException: The temporary upload location [/tmp/tomcat.3814974221022613431.8080/work/Tomcat/localhost/ROOT] is not valid
原因:
1.spring boot的应用服务在启动的时候,会生成在操作系统的/tmp目录下生成一个Tomcat.*的文件目录,用于"java.io.tmpdir"文件流操作
TomcatEmbeddedServletContainerFactory
2.程序对文件的操作时:会生成临时文件,暂存在临时文件中;
lunix 系统的tmpwatch 命令会删除10天未使用的临时文件;
长时间不操作,导致/tmp下面的tomcat临时文件目录被删除,且删除的文件不可恢复,上传文件时获取不到文件目录,报错
解决方案:
1.重启服务,临时方案:会重新生成tomcat目录,但是生产环境不建议如此操作;
2.1增加服务配置,自定义baseDir:
2.2启动时增加参数-Djava.io.tmpdir=自定义目录
3.修改tmpwatch 删除文件的逻辑,系统级别的命令,不建议操作
4.在网上看到有:编码的方式catch异常,生成删除的文件夹;(方法未验证)
参考:
https://github.com/spring-projects/spring-boot/issues/5009
https://github.com/spring-projects/spring-boot/issues/9616
相关文章推荐
- spring boot 上传文件 Caused by: java.io.IOException: The temporary upload location [/tmp/tomcat.**/work/
- spring boot上传文件 The temporary upload location is not valid
- Could not parse multipart servlet request; nested exception is java.io.IOException: The temporary upload location
- nested exception is java.io.IOException: The temporary upload location
- 向HDFS上传文件报 java.io.IOException: Bad connect ack with firstBadLink异常
- Spring boot + LayIM + t-io 实现文件上传、 监听用户状态的实例代码
- Spring boot(16) spring boot 线上故障 上传文件出错:org.springframework.web.multipart.MultipartException: Could
- 阿里巴巴dubbo处理文件上传下载 java.io.IOException: stream is closed
- [ Spring Boot ] org.apache.catalina.connector.ClientAbortException: java.io.IOException
- Spring Boot使用ServletFileUpload上传文件失败
- 基于spring-boot的文件上传和下载(包括图片的压缩)--第一篇(Java代码)
- java.io.IOException: The temporary job-output directory file:/usr/nutch1.4/runtime/local/sina/crawld
- SpringBoot文件上传控制及Java 获取和判断文件头信息
- [异常] Java文件上传异常org.apache.commons.fileupload.FileUploadBase$IOFileUploadException: Processing of mul
- Java Springboot结合FastDFS实现文件上传以及根据图片url将图片上传至图片服务器
- Spring--《Spring实战》The temporary upload location [/tmp/uploads] is not valid
- Java-上传文件Spring MultipartResolver 或者 ServletFileUpload
- 【JAVA-OSS】如何在spring-boot项目中使用oss上传下载文件
- 上传文件出错:org.apache.commons.fileupload.FileUploadBase$IOFileUploadException: Processing of multipart/form-data request failed. Stream ended unexpectedly
- 关于stuts2文件上传出错java.lang.NoSuchMethodException: com.cn.file.upload.UploadFile.uploadfile()