背景:项目有好几个功能模块都需要上传图片,也都开发测试完成,但上传的图片都放在同一个image文件路径下,为了方便后期维护,就想着把不同功能模块的图片分个文件夹。
public class SysConstant {
/** 分隔符 */
public static final String SEPARATOR = System.getProperty("file.separator");
/** 图片文件路径 */
public static final String PATH_FILE_IMAGE = SEPARATOR + "files" + SEPARATOR + "image" + SEPARATOR;
/** 图片文件目录 */
public static final String DIR_FILE_IMAGE = System.getProperty("user.dir") + PATH_FILE_IMAGE;
/** 订单图片文件路径 */
public static final String PATH_FILE_ORDER = SEPARATOR + "files" + SEPARATOR + "order" + SEPARATOR;
/** 订单图片文件目录 */
public static final String DIR_FILE_ORDER = System.getProperty("user.dir") + PATH_FILE_ORDER;
}
订单图片文件的路径和目录是新增的,把订单相关的图片地方,一处是存一处是取的值都改为DIR_FILE_ORDER,上传是成功的,文件夹里也有相关的文件,但访问就是404。
报错如下:
[WARN] (GlobalExceptionHandler.java:75 exception) 请求失败, 响应码:404, 参数:{}, Not Found:No message available, java.lang.Throwable:null
网上一搜索各种各样的错误,修改前使用image文件夹是正常的,添加个目录怎么就404,于是我全程搜索/image,就找到如下代码片段:
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/files/image/**").addResourceLocations("file:" + SysConstant.DIR_FILE_IMAGE).setCachePeriod(0);
}
于是复制一行,就修改了一下后面的路径
registry.addResourceHandler("/files/image/**").addResourceLocations("file:" + SysConstant.DIR_FILE_ORDER).setCachePeriod(0);
重启工程,再次访问,还是404,又是网上一顿搜索,看到了很多类似上面的代码片段,后来我仔细查看发现"/files/image/**"没有改,改成如下代码:
registry.addResourceHandler("/files/order/**").addResourceLocations("file:" + SysConstant.DIR_FILE_ORDER).setCachePeriod(0);
重启工程,再次访问,还是404,经过一番折腾发现接口返回的图片url居然包含了我电脑的路径:
http://localhost:8000/Users/adong/eclipse-workspace/projectName/files/order/05880A62B708B1AD4FA62D6227E2C81C-20210915112832398.jpg
翻看一下以前的日志,能正常访问的图片路径:
http://localhost:8000/files/image/05880A62B708B1AD4FA62D6227E2C81C-20210915112832398.jpg
于是又去细他比对一下代码,没想到从数据库取图片名字,拼接域名的时候,正常能访问的使用PATH_FILE_IMAGE,而我修改后使用的是DIR_FILE_ORDER,将返回图片路径的地方改为PATH_FILE_ORDER,重启工程,终于是能正常访问了。
总结:
1.存图片和取图片分别对应的是不样的,存图时要使用绝对路径,取图片要使用相对路径。
2.在WebMvcConfigurerAdapter文件中相对路径和绝对路径要添加映射关系。
3.仔细检查对比哪里是不是写的不正确。