最近在項目中涉及到Excle的導入功能,一般是咱們定義完模板供用戶下載,用戶按照模板填寫完後上傳;這裏模板位置resource/excel/test.xlsx,嘗試了四種讀取方式,而且測試了四種讀取方式分別的windows開發環境下(IDE中)讀取和生產環境(linux下jar包運行讀取)。
第一種:linux
ClassPathResource classPathResource = new ClassPathResource("excleTemplate/test.xlsx"); InputStream inputStream =classPathResource.getInputStream();
第二種:spring
InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("excleTemplate/test.xlsx");
第三種:windows
InputStream inputStream = this.getClass().getResourceAsStream("/excleTemplate/test.xlsx");
第四種:tomcat
File file = ResourceUtils.getFile("classpath:excleTemplate/test.xlsx"); InputStream inputStream = new FileInputStream(file);
經測試:
前三種方法在開發環境(IDE中)和生產環境(linux部署成jar包)均可以讀取到,第四種只有開發環境 時能夠讀取到,生產環境讀取失敗。
推測主要緣由是springboot內置tomcat,打包後是一個jar包,所以經過文件讀取獲取流的方式行不通,由於沒法直接讀取壓縮包中的文件,讀取只能經過流的方式讀取。
前三種均可以讀取到其實異曲同工,直接查看底層代碼都是經過類加載器讀取文件流,類加載器能夠讀取jar包中的編譯後的class文件,固然也是能夠讀取jar包中的文件流了。
用解壓軟件打開jar包查看結果以下:springboot
其中cst文件中是編譯後class文件存放位置,excleTemplate是模板存放位置,類加載器讀取的是cst下class文件,一樣能夠讀取excleTemplate下的模板的文件流了。測試