如何修复java.lang.IncompatibleClassChangeError:使用cxf实现类

时间:2019-04-28 02:38:52

标签: java cxf

在运行openjdk版本“ 1.8.0_201”的RedHat linux环境中,在tomcat 8上进行SOAP客户端调用时遇到了问题,而在Windows计算机(tomcat 8,Oracle Java)上的类似配置下,该调用也可以正常工作8)和AIX(Oracle Java 8,tomcat 7)。

这是堆栈跟踪:

java.lang.IncompatibleClassChangeError: Implementing class
        at java.lang.ClassLoader.defineClass1(Native Method)
        at java.lang.ClassLoader.defineClass(ClassLoader.java:763)
        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
        at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2401)
        at org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:859)
        at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1333)
        at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1185)
        at org.apache.cxf.ws.addressing.impl.AddressingFeatureApplier.initializeProvider(AddressingFeatureApplier.java:36)
        at org.apache.cxf.ws.addressing.WSAddressingFeature.initializeProvider(WSAddressingFeature.java:46)
        at org.apache.cxf.feature.AbstractFeature.initialize(AbstractFeature.java:49)
        at org.apache.cxf.frontend.ClientFactoryBean.applyFeatures(ClientFactoryBean.java:112)
        at org.apache.cxf.frontend.ClientFactoryBean.create(ClientFactoryBean.java:100)
        at org.apache.cxf.frontend.ClientProxyFactoryBean.create(ClientProxyFactoryBean.java:157)
        at org.apache.cxf.jaxws.JaxWsProxyFactoryBean.create(JaxWsProxyFactoryBean.java:142)
        at org.apache.cxf.jaxws.ServiceImpl.createPort(ServiceImpl.java:476)
        at org.apache.cxf.jaxws.ServiceImpl.getPort(ServiceImpl.java:343)
        at javax.xml.ws.Service.getPort(Service.java:160)

使用 cxf版本2.7.18

pom.xml代码段

      <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-frontend-jaxws</artifactId>
        <version>${cxf.version}</version>
      </dependency>
      <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http-jetty</artifactId>
        <version>${cxf.version}</version>
      </dependency>
      <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-transports-http</artifactId>
        <version>${cxf.version}</version>
      </dependency>
      <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-rt-rs-client</artifactId>
        <version>3.0.16</version>
      </dependency>

2 个答案:

答案 0 :(得分:0)

发生IncompatibleClassChangeError的原因是某些代码是针对某个API版本编译的,但是在运行时正在加载该API的不兼容版本。

(在这种情况下,“实现类”不兼容意味着一个类已声明为implements Something,但在运行时Something却是一个类而不是一个接口。此API不允许更改。)

问题是您所包含的stacktrace不能告诉我们不兼容发生在哪个类中以及不兼容的类。唯一真正的线索是CXF似乎正在加载“提供程序”

那该怎么办?

没有银弹。您将需要进行一些挖掘以找出实际的问题是什么:

  1. 检查从中获取了堆栈跟踪信息的日志,以获取其他日志消息,这些消息可能会告诉您正在加载的内容。
  2. 在运行时平台上检查各种CXF JAR文件的版本。
  3. 检查web应用程序本身和Tomcat的共享库目录中是否没有不同版本的JAR。
  4. 修改Tomcat日志记录配置,以将org.apache.catalina.loader软件包的日志记录级别设置为DEBUG。这将记录加载每个类的JAR文件。

答案 1 :(得分:0)

由于导入了不同版本的库和用于生成 WSDL 存根的插件,我获得了 java.lang.IncompatibleClassChangeError

这些依赖使我的应用程序在启动时崩溃

    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-spring-boot-starter-jaxws</artifactId>
        <version>3.3.0</version>
    </dependency>
    
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-codegen-plugin</artifactId>
        <version>3.4.3</version>
    </dependency>

修改所用插件的版本(在依赖项和插件声明中),应用程序启动时不会出错,Web 服务已正确部署并可以处理请求。

    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-spring-boot-starter-jaxws</artifactId>
        <version>3.3.0</version>
    </dependency>
    
    <dependency>
        <groupId>org.apache.cxf</groupId>
        <artifactId>cxf-codegen-plugin</artifactId>
        <version>3.3.0</version>
    </dependency>