最近在項目中涉及到Excle的導入功能,通常是我們定義完模板供用戶下載,用戶按照模板填寫完后上傳;這里待下載模板位置為resource/excelTemplate/test.xlsx,嘗試了四種讀取方式,並且測試了四種讀取方式分別的windows開發環境下(IDE中)讀取和生產環境(linux下jar包運行讀取)。
第一種:
ClassPathResource classPathResource = new ClassPathResource("excleTemplate/test.xlsx"); InputStream inputStream =classPathResource.getInputStream();
第二種:
InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("excleTemplate/test.xlsx");
第三種
InputStream inputStream = this.getClass().getResourceAsStream("/excleTemplate/test.xlsx");
第四種
File file = ResourceUtils.getFile("classpath:excleTemplate/test.xlsx"); InputStream inputStream = new FileInputStream(file);
經測試:
前三種方法在開發環境(IDE中)和生產環境(linux部署成jar包)都可以讀取到,第四種只有開發環境 時可以讀取到,生產環境讀取失敗。
推測主要原因是springboot內置tomcat,打包后是一個jar包,無法直接讀取jar包中的文件,讀取只能通過類加載器讀取。
前三種都可以讀取到其實殊途同歸,直接查看底層代碼都是通過類加載器讀取文件流,類加載器可以讀取jar包中的編譯后的class文件,當然也是可以讀取jar包中的excle模板了。
用解壓軟件打開jar包查看結果如下:

其中cst文件中是編譯后class文件存放位置,excleTemplate是模板存放位置,類加載器讀取的是cst下class文件,同樣可以讀取excleTemplate下的模板的文件流了。
所以總結一下:假如文件是在jar包中,讀取方式應當使用基於類加載器讀取文件流的方式,比如前三種方法;使用基於java中File方式的讀取,在jar包情況下是讀取不到的,比方說第四種。
感覺對你有幫助,就點個贊吧…
轉載鏈接:https://www.jianshu.com/p/7d7e5e4e8ae3