最近在項(xiàng)目中涉及到Excle的導(dǎo)入功能,通常是我們定義完模板供用戶下載,用戶按照模板填寫完后上傳;這里待下載模板位置為resource/excelTemplate/test.xlsx,嘗試了四種讀取方式,并且測(cè)試了四種讀取方式分別的windows開發(fā)環(huán)境下(IDE中)讀取和生產(chǎn)環(huán)境(linux下jar包運(yùn)行讀取)。
第一種:
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);
經(jīng)測(cè)試:
前三種方法在開發(fā)環(huán)境(IDE中)和生產(chǎn)環(huán)境(linux部署成jar包)都可以讀取到,第四種只有開發(fā)環(huán)境 時(shí)可以讀取到,生產(chǎn)環(huán)境讀取失敗。
推測(cè)主要原因是springboot內(nèi)置tomcat,打包后是一個(gè)jar包,無法直接讀取jar包中的文件,讀取只能通過類加載器讀取。
前三種都可以讀取到其實(shí)殊途同歸,直接查看底層代碼都是通過類加載器讀取文件流,類加載器可以讀取jar包中的編譯后的class文件,當(dāng)然也是可以讀取jar包中的excle模板了。
用解壓軟件打開jar包查看結(jié)果如下:
其中cst文件中是編譯后class文件存放位置,excleTemplate是模板存放位置,類加載器讀取的是cst下class文件,同樣可以讀取excleTemplate下的模板的文件流了。
所以總結(jié)一下:假如文件是在jar包中,讀取方式應(yīng)當(dāng)使用基于類加載器讀取文件流的方式,比如前三種方法;使用基于java中File方式的讀取,在jar包情況下是讀取不到的,比方說第四種。
感覺對(duì)你有幫助,就點(diǎn)個(gè)贊吧……