java.lang.ClassNotFoundException:org.apache.poi.ss.usermodel.Workbook

Posted

技术标签:

【中文标题】java.lang.ClassNotFoundException:org.apache.poi.ss.usermodel.Workbook【英文标题】:java.lang.ClassNotFoundException: org.apache.poi.ss.usermodel.Workbook 【发布时间】:2017-08-17 08:38:09 【问题描述】:

我正在尝试访问 Apache Workbook 模块的 excel 文件。代码有时运行完美,但大多数情况下我收到一条错误消息:

例外

javax.servlet.ServletException: Servlet 执行抛出异常 org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)

根本原因

java.lang.NoClassDefFoundError: org/apache/poi/ss/usermodel/Workbook

根本原因

java.lang.ClassNotFoundException: org.apache.poi.ss.usermodel.Workbook

我查了一下,发现是 jar 文件问题。尝试从我这边修复它,但我仍然遇到同样的错误。

这是我的pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>XYZ</groupId>
    <artifactId>ABC</artifactId>
    <packaging>war</packaging>
    <version>0.0.1-SNAPSHOT</version>
    <name>ScriptsGenerator Maven Webapp</name>
    <url>http://maven.apache.org</url>
  <dependencies>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>3.8.1</version>
        <scope>test</scope>
      </dependency>
      <!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
      <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.15</version>
      </dependency>
    <dependency>
        <groupId>org.lucee</groupId>
        <artifactId>poi-ooxml-schemas</artifactId>
        <version>3.15.0</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
            <version>3.15</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
    <dependency>
            <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/com.googlecode.json-simple/json-simple -->
    <dependency>
        <groupId>com.googlecode.json-simple</groupId>
        <artifactId>json-simple</artifactId>
        <version>1.1.1</version>
    </dependency>
    <dependency>
        <groupId>commons-logging</groupId>
        <artifactId>commons-logging</artifactId>
        <version>1.2</version>
    </dependency>
    <dependency>
            <groupId>commons-codec</groupId>
            <artifactId>commons-codec</artifactId>
            <version>1.10</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
    <dependency>
        <groupId>org.apache.struts</groupId>
        <artifactId>struts2-core</artifactId>
        <version>2.5.8</version>
      </dependency>
      <!-- https://mvnrepository.com/artifact/org.apache.xmlbeans/xmlbeans -->
    <dependency>
        <groupId>org.apache.xmlbeans</groupId>
        <artifactId>xmlbeans</artifactId>
        <version>2.6.0</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/dom4j/dom4j -->
    <dependency>
            <groupId>dom4j</groupId>
            <artifactId>dom4j</artifactId>
            <version>1.6.1</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-collections4 -->
    <dependency>
       <groupId>org.apache.commons</groupId>
       <artifactId>commons-collections4</artifactId>
       <version>4.1</version>
    </dependency>
    <dependency>
  <groupId>commons-fileupload</groupId>
  <artifactId>commons-fileupload</artifactId>
  <version>1.2</version>
  </dependency>

    </dependencies>
    <build>
      <finalName>AAAA</finalName>
    </build>
  </project>

我哪里出错了?

【问题讨论】:

【参考方案1】:

请检查apache poi jars是否被下载,

还可以尝试对 poi-ooxml-schemas 使用以下依赖项

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml-schemas -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml-schemas</artifactId>
    <version>3.15</version>
</dependency>

【讨论】:

我转到属性 > Java 构建路径 > 库。我在 Maven Dependencies 下看到了 jars。【参考方案2】:

看起来您是在一个 servlet 容器中运行它,这可能意味着该容器有自己的一组 jar 文件。例如,对于 Tomcat,它将位于 Tomcat/lib 目录中。检查您的 servlet 容器正在使用哪些 jar,以查看其中一个是否与您正在使用的不兼容。

您要寻找的是旧版本的 poi,它没有您需要的类。如果这样的 jar 存在并且在正确的 jar 之前被加载,它可能会导致您看到的问题,即使您的 Web 应用程序本身具有正确的版本。

【讨论】:

我不确定如何检查罐子是否兼容。能详细点吗?【参考方案3】:

清理您的项目,删除 User_Directory/.m2 文件夹的内容并重新运行您的项目

在windows系统下你可以找到maven repo path as C:\Users\user_name\.m2

在linux系统下你可以找到maven repo路径为/home/user_name/.m2

【讨论】:

我没有看到 .m2 文件夹。你能帮我解决吗? 如果您没有强制更改 maven 设置,.m2 文件夹必须在您的用户/主目录中。

以上是关于java.lang.ClassNotFoundException:org.apache.poi.ss.usermodel.Workbook的主要内容,如果未能解决你的问题,请参考以下文章