Maven 和 RAD 产生不同的 EAR

Maven and RAD produce different EARs

我必须从 RAD 9.5 和 maven 构建一个项目(Parent 和 EAR,其中包含 jar、ejb 和 2 个 war 模块)。

当我从 maven 命令行构建项目时,一切正常。它正在创建在 WebSphere 8.5.5 上运行的瘦 wars 存档。

尝试从 RAD 更新项目或导出 EAR 时,我得到的文件不同且无法工作,EJB 的依赖项之一出现 ClassNotFoundException。

进一步观察,我发现类路径部分的 MANIFEST.MF 有所不同。 Maven 项目将带有 lib/ 前缀和 m2e/RAD 的实例放在那里,就像这样:

Class-Path: lib/log4j-api-2.6.jar lib/log4j-core-2.6.jar lib/junit-4.12.jar lib/hamcrest-core-1.3.

纯 maven 和:

Class-Path: log4j-api-2.6.jar log4j-core-2.6.jar junit-4.12.jar hamcrest-core-1.3.

我尝试更新一个项目,使用 pom.xml 中的设置。这是我最接近工作的应用程序。

我当前的 ejb 插件配置:

        <plugin>
            <artifactId>maven-ejb-plugin</artifactId>
            <version>2.5</version>
            <configuration>
                <archive>
                    <manifest>
                        <addClasspath>true</addClasspath>
                    </manifest>
                </archive>
                <ejbVersion>3.1</ejbVersion>
            </configuration>
        </plugin>

和异常(最低级别):

Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager
at java.net.URLClassLoader.findClass(URLClassLoader.java:600)
at com.ibm.ws.bootstrap.ExtClassLoader.findClass(ExtClassLoader.java:243)
at java.lang.ClassLoader.loadClassHelper(ClassLoader.java:786)
at java.lang.ClassLoader.loadClass(ClassLoader.java:764)
at com.ibm.ws.bootstrap.ExtClassLoader.loadClass(ExtClassLoader.java:134)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:62)
at com.ibm.ws.classloader.ProtectionClassLoader.loadClass(ProtectionClassLoader.java:58)
at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:585)
at java.lang.ClassLoader.loadClass(ClassLoader.java:741)
... 75 more

我想这是问题所在,但我不知道如何修复它。

更新: 尝试添加到清单部分:

<classpathPrefix>lib/</classpathPrefix>

同样的结果。

这是一个迂回的答案,但您可能会发现从 EE 项目开始更成功:WAR、EAR 等,然后使用 "Convert to Maven projects" 选项。

您可以找到信息 here and here

一旦您了解了将映射回 RAD 中的 EE 项目结构的 Maven 结构,您也可以在另一个方向上工作。如果您对现有的项目格式感到满意,不确定还有多少工作要做。

我不确定我是否回答了你的问题,但这对于评论来说太长了,所以这里...

我注意到,如果我将 maven 生成的 manifest.mf 复制到项目中,然后使用 RAD 构建项目,它会将正确的文件带到最终的 EAR 中。这是一种解决方法。此外,根据 this:m2e-wtp 将仅在不存在时生成清单。