问题背景:项目中需要读取resource路径下文件,本地Windows环境没有问题,部署到Linux环境找不到文件,导出文件为空。
解决方案:
1.以下是两种常见的获取路径方式,先获取路径,再通过路径获取文件,Linux环境均行不通。
String path = this.getClass().getClassLoader().getResource("template/classTemplate.xlsx").getPath();
String path = new ClassPathResource("template/classTemplate.xlsx").getPath();
2.以流的形式获取,再进行其他操作,问题解决。
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("template/classTemplate.xlsx");
3.完整代码
@GetMapping("/getClassTemplate")
public void getClassTemplate(HttpServletResponse response) throws UnsupportedEncodingException {
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setCharacterEncoding("utf-8");
FileUtils.setAttachmentResponseHeader(response, "类库模板" + DateUtils.dateTimeNow() + ".xlsx");
try {
InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("template/classTemplate.xlsx");
byte[] buff = new byte[1024];
while (inputStream.read(buff) != -1){
response.getOutputStream().write(buff);
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}