最近在使用文件上传功能,使用的是apache的commons-fileupload控件,本地测试时,window上能正确使用,部署在linux上也能正确使用,但部署到线上环境时,能进入图片上传的方法,但在调用commons-fileupload的方法时,却出现异常,不能继续执行,后经检查,发现如下:
(1)本地测试linux时,是在root用户下部署tomcat的,而到正式环境时,线上不能使用root用户,只能使用普通用户。
(2)commons-fileupload上传时,都是需要先在目的地服务器上新建一个临时目录,将文件先上传到临时目录,然后在上传到我们调用方法配置的路径:
DiskFileUpload fu = new DiskFileUpload();
fu.setSizeMax(MaxSize); //
fu.setSizeThreshold(4096);
//配置临时路径
fu.setRepositoryPath("/");
commons-fileupload中临时路径方法如下:
/**
* Sets the location used to temporarily store files that are larger
* than the configured size threshold.
*
* @param repositoryPath The path to the temporary file location.
*
* @see #getRepositoryPath()
*
* @deprecated 1.1 Use <code>DiskFileItemFactory</code> instead.
*/
@Deprecated
public void setRepositoryPath(String repositoryPath) {
fileItemFactory.setRepository(new File(repositoryPath));
}
(3)对linux来说,权限是严格控制的,我们再代码中直接写死的是根路径,而非root用户,是不能在linux根路径底下去操作文件的。
综上分析,文件上传失效是由于使用普通用户部署项目时,没有权限创建临时目录,导致上传不成功。
解决办法:
针对权限问题,调用commons-fileupload的setRespositoryPath,路径修改为可配置,在linux上部署时,根据需要配置为对应linux用户的底下目录,避免无root权限问题,这样就解决了权限问题,最后,上传文件成功:
DiskFileUpload fu = new DiskFileUpload();
fu.setSizeMax(MaxSize); //
fu.setSizeThreshold(4096);
//配置临时路径
fu.setRepositoryPath(tempFilePath);