您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“POI導(dǎo)出Excel報(bào)錯(cuò)No such file or directory怎么辦”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“POI導(dǎo)出Excel報(bào)錯(cuò)No such file or directory怎么辦”這篇文章吧。
場(chǎng)景重現(xiàn)
Apache POI
Linux
Tomcat
如上所示,當(dāng)時(shí)在linux+tomcat的環(huán)境下,使用apache的poi導(dǎo)出excel的時(shí)候就會(huì)報(bào)“No such file or directory”的錯(cuò)誤。
錯(cuò)誤信息
java.lang.RuntimeException: java.io.IOException: No such file or directory at org.apache.poi.xssf.streaming.SXSSFWorkbook.createAndRegisterSXSSFSheet(SXSSFWorkbook.java:569) at org.apache.poi.xssf.streaming.SXSSFWorkbook.createSheet(SXSSFWorkbook.java:558) at com.app.util.ExcelIOUtil.write(ExcelIOUtil.java:46) at com.app.controllers.DrivingSchoolController.download(DrivingSchoolController.java:106) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at com.mvc.invoke.ActionInvoker.invoke(ActionInvoker.java:75) at com.mvc.MvcDispatcher.service(MvcDispatcher.java:119) at com.mvc.MvcFilter.doFilter(MvcFilter.java:67) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1023) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) at org.apache.tomcat.util.net.AprEndpoint$SocketWithOptionsProcessor.run(AprEndpoint.java:1810) at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) at java.lang.Thread.run(Thread.java:662)
解決方案
咱們先說(shuō)解決方案,因?yàn)榻鉀Q的辦法非常簡(jiǎn)單,只需要在tomcat的根目錄下建一個(gè)“temp”的文件夾即可。
錯(cuò)誤原因
之所以會(huì)出現(xiàn)這個(gè)錯(cuò)誤,是因?yàn)閜oi默認(rèn)將導(dǎo)出的excel導(dǎo)出到系統(tǒng)的臨時(shí)目錄,而當(dāng)時(shí)那個(gè)linux的tomcat下不存在那個(gè)temp文件夾,所以就找不到目錄了。其實(shí)不管是在什么系統(tǒng)環(huán)境下,只要tomcat根目錄沒(méi)有temp都會(huì)出現(xiàn)這個(gè)情況??纯聪旅鎝oi的源碼你就明白了。
public void write(OutputStream stream) throws IOException{ for (SXSSFSheet sheet : _xFromSxHash.values()){ sheet.flushRows(); } //保存到臨時(shí)目錄 File tmplFile = File.createTempFile("poi-sxssf-template", ".xlsx"); tmplFile.deleteOnExit(); FileOutputStream os = new FileOutputStream(tmplFile); _wb.write(os); os.close(); //Substitute the template entries with the generated sheet data files injectData(tmplFile, stream); tmplFile.delete(); }
以上是“POI導(dǎo)出Excel報(bào)錯(cuò)No such file or directory怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。