在 Weblogic 上部署 OpenID Azure AD java web 应用程序时出现 NoClassDefFoundError

时间:2021-05-06 17:26:56

标签: java azure weblogic adal

我正在尝试使用 OpenIDConnect 方法为我的 Web 应用程序集成 Azure AD。当我尝试在 weblogic 上部署构建的 ear 文件时,我得到 NoClassDefFound for

<块引用>

com.nimbusds.openid.connect.sdk.AuthenticationSuccessResponse

。我已经在 web-inf/lib 文件夹中包含了 oauth2-oidc-sdk-5.24.1.jar,还验证了它实际上存在于 ear 文件中,但应用程序部署失败,抱怨它不是能够找到这个类。

我发现了类似的问题 here。因此,我尝试将 oauth2-oidc-sdk-5.24.1.jar 和 gson jar 文件作为库与我的 Java Web 应用程序一起部署,但这也无济于事。

如果我能得到任何指示或建议来克服这个错误,我将不胜感激。

部署期间的完整堆栈跟踪:

Caused By: java.lang.NoClassDefFoundError: com/nimbusds/openid/connect/sdk/AuthenticationSuccessResponse
        at java.lang.Class.getDeclaredMethods0(Native Method)
        at java.lang.Class.privateGetDeclaredMethods(Class.java:2436)
        at java.lang.Class.getDeclaredMethods(Class.java:1793)
        at weblogic.j2ee.dd.xml.BaseJ2eeAnnotationProcessor.getMethods(BaseJ2eeAnnotationProcessor.java:1055)
        at weblogic.j2ee.dd.xml.BaseJ2eeAnnotationProcessor.getMethods(BaseJ2eeAnnotationProcessor.java:1043)
        at weblogic.j2ee.dd.xml.BaseJ2eeAnnotationProcessor.processJ2eeAnnotations(BaseJ2eeAnnotationProcessor.java:99)
        at weblogic.j2ee.dd.xml.J2eeAnnotationProcessor.processJ2eeAnnotations(J2eeAnnotationProcessor.java:37)
        at weblogic.servlet.internal.WebAnnotationProcessorImpl.processFilters(WebAnnotationProcessorImpl.java:239)
        at weblogic.servlet.internal.WebAnnotationProcessorImpl.processJ2eeAnnotations(WebAnnotationProcessorImpl.java:210)
        at weblogic.servlet.internal.WebAnnotationProcessorImpl.processAnnotations(WebAnnotationProcessorImpl.java:105)
        at weblogic.servlet.internal.WebAppServletContext.processAnnotations(WebAppServletContext.java:1370)
        at weblogic.servlet.internal.WebAppServletContext.<init>(WebAppServletContext.java:450)
        at weblogic.servlet.internal.WebAppServletContext.<init>(WebAppServletContext.java:494)
        at weblogic.servlet.internal.HttpServer.loadWebApp(HttpServer.java:418)
        at weblogic.servlet.internal.WebAppModule.registerWebApp(WebAppModule.java:976)
        at weblogic.servlet.internal.WebAppModule.prepare(WebAppModule.java:384)
        at weblogic.application.internal.flow.ScopedModuleDriver.prepare(ScopedModuleDriver.java:176)
        at weblogic.application.internal.flow.ModuleListenerInvoker.prepare(ModuleListenerInvoker.java:199)
        at weblogic.application.internal.flow.DeploymentCallbackFlow$1.next(DeploymentCallbackFlow.java:517)
        at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)
        at weblogic.application.internal.flow.DeploymentCallbackFlow.prepare(DeploymentCallbackFlow.java:159)
        at weblogic.application.internal.flow.DeploymentCallbackFlow.prepare(DeploymentCallbackFlow.java:45)
        at weblogic.application.internal.BaseDeployment$1.next(BaseDeployment.java:648)
        at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)
        at weblogic.application.internal.BaseDeployment.prepare(BaseDeployment.java:191)
        at weblogic.application.internal.EarDeployment.prepare(EarDeployment.java:59)
        at weblogic.application.internal.DeploymentStateChecker.prepare(DeploymentStateChecker.java:154)
        at weblogic.deploy.internal.targetserver.AppContainerInvoker.prepare(AppContainerInvoker.java:60)
        at weblogic.deploy.internal.targetserver.operations.ActivateOperation.createAndPrepareContainer(ActivateOperation.java:208)
        at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doPrepare(ActivateOperation.java:98)
        at weblogic.deploy.internal.targetserver.operations.AbstractOperation.prepare(AbstractOperation.java:217)
        at weblogic.deploy.internal.targetserver.DeploymentManager.handleDeploymentPrepare(DeploymentManager.java:747)
        at weblogic.deploy.internal.targetserver.DeploymentManager.prepareDeploymentList(DeploymentManager.java:1216)
        at weblogic.deploy.internal.targetserver.DeploymentManager.handlePrepare(DeploymentManager.java:250)
        at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.prepare(DeploymentServiceDispatcher.java:159)
        at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doPrepareCallback(DeploymentReceiverCallbackDeliverer.java:171)

###################################

2021/06/02 更新

为了解决版本兼容性问题,我不得不选择低于特定版本的依赖项,以使其不会抛出JDK1.6的错误,并且必须在JDK6中重新编译microsoft adal4j(jdk1.7及更高版本支持adal4j jar )

    <groupId>com.nimbusds</groupId>
    <artifactId>nimbus-jose-jwt</artifactId>
    <classifier>jdk16</classifier>
    <version>5.9</version>
    

    <groupId>com.nimbusds</groupId>
    <artifactId>oauth2-oidc-sdk</artifactId>
    <classifier>jdk16</classifier>
    <version>5.24.1</version>
    </dependency>

如果 JDK 是 1.7,以下是对我有用的特定版本:

        <dependency>
        <groupId>com.microsoft.azure</groupId>
        <artifactId>adal4j</artifactId>
        <version>1.6.0</version>
        </dependency>
    
        <dependency>
        <groupId>com.nimbusds</groupId>
        <artifactId>oauth2-oidc-sdk</artifactId>
        <version>5.24.1</version>
        </dependency>
        
        <dependency>
        <groupId>com.nimbusds</groupId>
        <artifactId>nimbus-jose-jwt</artifactId>
        <version>7.8</version>
        </dependency>

希望这对在 JDK1.6 和 JDK1.7 上遇到类似错误的人有所帮助

1 个答案:

答案 0 :(得分:1)

这通常是由于版本不兼容造成的。您可以尝试不同版本的 oauth2-oidc-sdk,直到找到兼容的软件包。

或者你也可以改变spring的版本来达到评论中提到的版本兼容的目的。

相关问题