【POI】解析xls報錯:java.util.zip.ZipException: error in opening zip file


今天使用POI解析XLS,報錯如下:

Servlet.service() for servlet [rest] in context with path [/cetBrand] threw exception [Request processing failed; nested exception is org.apache.poi.openxml4j.exceptions.InvalidOperationException: Can't open the specified file: 'd:\cet_Brand\examSorce\Sheet名不對.xls'] with root cause
java.util.zip.ZipException: error in opening zip file
    at java.util.zip.ZipFile.open(Native Method)
    at java.util.zip.ZipFile.<init>(ZipFile.java:219)
    at java.util.zip.ZipFile.<init>(ZipFile.java:149)
    at java.util.zip.ZipFile.<init>(ZipFile.java:163)
    at org.apache.poi.openxml4j.util.ZipSecureFile.<init>(ZipSecureFile.java:142)
    at org.apache.poi.openxml4j.opc.internal.ZipHelper.openZipFile(ZipHelper.java:158)
    at org.apache.poi.openxml4j.opc.ZipPackage.<init>(ZipPackage.java:133)
    at org.apache.poi.openxml4j.opc.OPCPackage.open(OPCPackage.java:257)
    at org.apache.poi.openxml4j.opc.OPCPackage.open(OPCPackage.java:202)
    at org.apache.poi.xssf.usermodel.XSSFWorkbook.<init>(XSSFWorkbook.java:302)
    at com.junlong.controller.ExamController.uploadMaterial(ExamController.java:259)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)

 

 

報錯原因是因為:

后台代碼:

XSSFWorkbook workbook = new XSSFWorkbook(thisFile);
        XSSFSheet  sheet = workbook.getSheet("成績單");

這個邏輯沒有錯 就是我解析的是.xls文件 而使用的是XSSFWorkbook類,應該使用

HSSFWorkbook workbook = new HSSFWorkbook(is);
        HSSFSheet sheet = workbook.getSheet("成績單");

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM