今天在写项目的时候出现了使用getResourceAsStream()在web项目中获取不到配置文件的原因
先放出解决后的代码:
@ApiOperation("下载成绩导入模板") @GetMapping("getAchievementTemplate") public void getAchievementTemplate(HttpServletResponse response) throws Exception { try { String url = Thread.currentThread().getContextClassLoader().getResource("chengjitemplate.xlsx").getFile(); FileInputStream fileInputStream = new FileInputStream(url); Workbook workbook = new XSSFWorkbook(fileInputStream); Sheet sheetAt = workbook.getSheetAt(0); Row row = sheetAt.getRow(2); CellStyle[] cellStyles = new CellStyle[row.getLastCellNum()]; for (int i = 0; i < cellStyles.length; i++) { cellStyles[i] = row.getCell(i).getCellStyle(); } // response.setContentType("application/vnd.ms-excel;charset=utf-8"); String fileName = URLEncoder.encode("学生体测成绩信息录入表.xlsx","UTF-8"); response.setContentType("application/octet-stream"); response.setHeader("content-disposition", "attachment;filename=" + fileName); response.setHeader("filename",fileName); // OutputStream os = response.getOutputStream(); // response.setHeader("Content-disposition", "attachment;filename=" + URLEncoder.encode("学生体测成绩信息录入表","UTF-8")+".xls");//默认Excel名称 workbook.write(response.getOutputStream()); }catch (Exception E){ throw new Exception(E.getMessage()); }finally { } }
就是通过类加载来进行载入文件的时候会出现加载不进来的情况,用了绝对路径才得以解决。
1.先放出来目录
2.java应用程序测试没有问题
3.当放入web项目运行后直接显示为空
4.当在java应用程序,我们将配置文件放在src下面,程序能够读取到。当放入web项目中,发现classes目录下也同样生成了配置文件,但是不知为何还是读取不到
5.后来在网上查了很长时间,找到这个方法得到配置文件的路径
Thread.currentThread().getContextClassLoader().getResource(“mybatis-config.xml”).getFile();
->当在java应用程序运行时路径
->当放在web项目运行
在这里发现,配置文件存放的目录并没有在classes下,而是在WEB-INF/classes下面
6.我的解决方案:
通过Thread.currentThread().getContextClassLoader().getResource(“mybatis-config.xml”).getFile()来获取绝对路径,直接使用绝对路径来实现加载配置文件
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/106033.html