java.lang.ClassNotFoundException:将 xalan 升级到 2.7.3 后抛出 org.apache.xml.serializer.OutputPropertiesFactory

Tal*_*evi 5 java excel xalan

我有java代码将一些数据导出到excel文件中。(我只在下面包含了我认为代码中的相关部分)

一切工作正常,但后来我将 xalan 从 2.7.2 升级到 2.7.3,它停止工作。原因 - java.lang.ClassNotFoundException: org.apache.xml.serializer.OutputPropertiesFactory

异常在“wb.write(fileOutputStream);”处引发 export() 方法下的行

import org.apache.logging.log4j.Level;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
     
private Workbook wb;

            private void init(String targetPath, String fileName, ExcelExportType exportType) {
                exportedFile = new File(Paths.get(targetPath, fileName  + FILE_EXTENSION).toString());
                try {
                    fileOutputStream = new FileOutputStream(exportedFile);
                    // if file doesn't exists, then create it
                    if (!exportedFile.exists()) {
                        exportedFile.createNewFile();
                    }
                } catch (Exception e) {
                    throw new RuntimeException("Init failed. File " + exportedFile.getName() + " cannot be found");
                }
        
                switch (exportType) {
                    case MS_EXCEL_2007_AND_UP_STREAMING:
                        wb = new SXSSFWorkbook();
                        break;
                    default:
                        throw new RuntimeException("Unsupported export type");
                }
        
                wb.setMissingCellPolicy(Row.MissingCellPolicy.CREATE_NULL_AS_BLANK);
                creationHelper = wb.getCreationHelper();
                sheet = wb.createSheet(getSheetName());
                Font font = wb.createFont();
                font.setFontName(DEFAULT_FONT_NAME);
        
                if(sheet instanceof SXSSFSheet) {
                    ((SXSSFSheet) sheet).trackAllColumnsForAutoSizing();
                }
        
                format = wb.createDataFormat();
        
                headerFont = wb.createFont();
                headerFont.setFontName(DEFAULT_FONT_NAME);
                headerFont.setBold(true);
        
                cellFont = wb.createFont();
                cellFont.setFontName(DEFAULT_FONT_NAME);
        
            }
        
        public File export() {
            double factor = 390;
            for (int i = 0; i < numOfColumns; i++) {
                sheet.autoSizeColumn(i);
                sheet.setColumnWidth(i, getWidth((int)(maxColumnWidth.get(i) * factor)));
            }
        
            sheet.createFreezePane(0,1);
        
            try {
                wb.write(fileOutputStream);
                fileOutputStream.close();
                wb.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        
            return exportedFile;
        }
Run Code Online (Sandbox Code Playgroud)

根据链接, https://xalan.apache.org/xalan-j/

Xalan-Java 版本 2.7.3 可与 Xerces-Java 配合使用,并且该发行版包括 Xerces-Java 2.12.2 中的 xercesImpl.jar。

Xalan-Java 实现位于xalan.jar 和serializer.jar 中。SAX、DOM 和 JAXP 1.3 接口位于 xml-apis.jar 中。

所以也许我需要以不同的方式实现代码?知道我该如何解决这个问题吗?

Tal*_*evi 10

通过将其添加到我的 Maven 依赖项来修复

    <dependency>
        <groupId>xalan</groupId>
        <artifactId>serializer</artifactId>
        <version>2.7.3</version>
    </dependency>
Run Code Online (Sandbox Code Playgroud)