首页 > 解决方案 > 本地依赖的 Quarkus ClassNotFoundException

问题描述

我正在尝试将项目迁移到 Quarkus。该项目依赖于本地 .jar 文件。使用 Quarkus 运行应用程序会导致java.lang.NoClassDefFoundError/java.lang.ClassNotFoundException用于驻留在所述 jar 中的类。

我使用 gradle 作为构建工具,并使用以下方法将本地 jar 文件添加为依赖项:

implementation fileTree(dir: 'libs', include: ['*.jar'])

假设库包含一些Foo带有静态方法的类init(),那么以下代码会导致错误:

// From the local jar
import org.somepackage.Foo;

@Startup
@Singleton
public class Main {

  @PostConstruct
  public void initLocalLibrary() {
    Foo.init();
  }

}

确切的输出是

2020-04-19 18:31:21,266 ERROR [io.qua.application] (main) Failed to start application: java.lang.NoClassDefFoundError: org/somepackage/Foo
    at Main.initLocalLibrary(Main.java:)
    at Main.initLocalLibrary_Bean.create(Main_Bean.zig:129)
    at Main_Bean.create(Main_Bean.zig:183)
Caused by: java.lang.ClassNotFoundException: org.somepackage.Foo

    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:581)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:322)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:275)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:322)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:275)
    ... 35 more

2020-04-19 18:31:21,302 ERROR [io.qua.dev.DevModeMain] (main) Failed to start Quarkus: java.lang.RuntimeException: Failed to start quarkus
    at io.quarkus.runner.ApplicationImpl.doStart(ApplicationImpl.zig:232)
    at io.quarkus.runtime.Application.start(Application.java:90)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at io.quarkus.runner.bootstrap.StartupActionImpl.run(StartupActionImpl.java:99)
    at io.quarkus.dev.IsolatedDevModeMain.firstStart(IsolatedDevModeMain.java:60)
    at io.quarkus.dev.IsolatedDevModeMain.accept(IsolatedDevModeMain.java:236)
    at io.quarkus.dev.IsolatedDevModeMain.accept(IsolatedDevModeMain.java:39)
    at io.quarkus.bootstrap.app.CuratedApplication.runInCl(CuratedApplication.java:131)
    at io.quarkus.bootstrap.app.CuratedApplication.runInAugmentClassLoader(CuratedApplication.java:84)
    at io.quarkus.dev.DevModeMain.start(DevModeMain.java:113)
    at io.quarkus.dev.DevModeMain.main(DevModeMain.java:54)

在没有 Quarkus 的情况下运行应用程序可以正常工作。

标签: javagradlequarkus

解决方案


请尝试更换

implementation fileTree(dir: 'libs', include: ['*.jar'])

api fileTree(dir: 'libs', include: ['*.jar'])


推荐阅读