CXF代码生成Maven插件无法在OpenJDK 11上工作。

15

我之前一直在使用JDK 9&10和CXF代码生成插件3.2.5和3.2.6,没有遇到任何问题。但是今天我尝试将我的代码库从Oracle JDK 10更新到OpenJDK 11 build 28,但是我总是得到相同的错误:

[INFO] Error occurred during initialization of boot layer
[INFO] java.lang.module.FindException: Module java.xml.ws not found
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1.747 s
[INFO] Finished at: 2018-10-17T16:38:38+02:00
[INFO] Final Memory: 17M/60M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.cxf:cxf-codegen-plugin:3.2.6:wsdl2java (cerberus-wsdl) on project cerberus: 
[ERROR] Exit code: 1
[ERROR] Command line was: /opt/prod_jdk/bin/java --add-modules java.activation,java.xml.bind,java.xml.ws --add-exports=java.xml.bind/com.sun.xml.internal.bind.v2.runtime=ALL-UNNAMED --add-exports=jdk.xml.dom/org.w3c.dom.html=ALL-UNNAMED --add-exports=java.xml/com.sun.org.apache.xerces.internal.impl.xs=ALL-UNNAMED --add-exports=java.xml.bind/com.sun.xml.internal.bind.marshaller=ALL-UNNAMED --add-opens java.xml.ws/javax.xml.ws.wsaddressing=ALL-UNNAMED --add-opens java.base/java.security=ALL-UNNAMED --add-opens java.base/java.net=ALL-UNNAMED --add-opens java.base/java.lang=ALL-UNNAMED --add-opens java.base/java.util=ALL-UNNAMED --add-opens java.base/java.util.concurrent=ALL-UNNAMED -jar /tmp/cxf-tmp-2828938832312113909/cxf-codegen12095310072621993552.jar /tmp/cxf-tmp-2828938832312113909/cxf-w2j12256414556760820901args

这是我的pom.xml文件,使用了CXF代码生成插件:

<plugin>
                <groupId>org.apache.cxf</groupId>
                <artifactId>cxf-codegen-plugin</artifactId>
                <version>3.2.6</version>
                <configuration>
                    <fork>once</fork>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>javax.annotation</groupId>
                        <artifactId>javax.annotation-api</artifactId>
                        <version>1.3.2</version>
                    </dependency>

                    <dependency>
                        <groupId>javax.activation</groupId>
                        <artifactId>javax.activation-api</artifactId>
                        <version>1.2.0</version>
                    </dependency>

                    <dependency>
                        <groupId>javax.xml.bind</groupId>
                        <artifactId>jaxb-api</artifactId>
                        <version>2.3.1</version>
                    </dependency>

                    <dependency>
                        <groupId>org.glassfish.jaxb</groupId>
                        <artifactId>jaxb-runtime</artifactId>
                        <version>2.3.1</version>
                    </dependency>

                    <dependency>
                        <groupId>javax.xml.ws</groupId>
                        <artifactId>jaxws-api</artifactId>
                        <version>2.3.1</version>
                    </dependency>

                    <dependency>
                        <groupId>com.sun.xml.ws</groupId>
                        <artifactId>jaxws-rt</artifactId>
                        <version>2.3.1</version>
                    </dependency>
                </dependencies>
<executions>...</executions>
<plugin>

我是否漏掉了什么?据我所知,这应该与JDK 9和10的工作方式相同。有一个问题https://issues.apache.org/jira/browse/CXF-7741,讨论JDK 11的兼容性,但我认为这是针对CXF框架而不是插件。


  1. 你的命令行读取了比你共享的Maven配置部分更多的参数。你是如何指定这些参数的?
  2. 你代码中哪个类确切依赖于java.xml.ws模块?
- Naman
  1. 命令行是由插件生成的,我猜测。所以Maven在编译目标中执行代码生成,CXF运行命令,所以我对命令一无所知(如果我错了,请纠正我)。
  2. 和第一个问题一样,CXF codegen插件使用这个模块来通过WSDL生成客户端代码。
- Nico
如果你真的不需要这些依赖项,那么尝试从插件配置中删除这些依赖项,这样事情就应该正常工作了。 - Naman
@nullpointer 这个插件肯定需要 java.xml.ws,它是一个 WSDL 解析器和 JAXWS+JAXB 类代码生成工具。虽然可以想象出不使用 java.xml.ws 的类似工具,但说实话这种可能性几乎为零。我会说这个模块绝对需要在类路径上(或者至少不会尝试首先将其删除)。 - GPI
是的,模块是插件所需的,问题在于CXF插件没有正确读取类party或其他内容,欢迎提供解决方法 :) - Nico
2个回答

27
这个问题将在cxf 3.3.0中得到解决(https://issues.apache.org/jira/browse/CXF-7852)。
目前,您可以在https://github.com/apache/cxf的mvn-plugins目录中运行mvn install来构建插件,并在pom中将版本设置为3.3.0-SNAPSHOT。 编辑: 插件在apache快照存储库中,所以最好从那里获取:
<pluginRepositories>         
   <pluginRepository>
      <id>apache.snapshots</id>
      <name>Maven Plugin Snapshots</name>
      <url>http://repository.apache.org/snapshots/</url>
      <snapshots>
        <enabled>true</enabled>
      </snapshots>
    </pluginRepository>
</pluginRepositories>
<build>
  <plugins>
    <plugin>
      <groupId>org.apache.cxf</groupId>
      <artifactId>cxf-codegen-plugin</artifactId>
      <version>3.3.0-SNAPSHOT</version>
...

注意 (2019-01-28): 插件现在已经 发布, 我们可以像往常一样添加依赖:

<dependency>
  <groupId>org.apache.cxf</groupId>
  <artifactId>cxf-codegen-plugin</artifactId>
  <version>3.3.0</version>
  <type>maven-plugin</type>
</dependency>

对于复杂的构建,其中大部分需要Java 8,应使用toolchains插件来强制使用Java 10以使cxf-codegen-plugin正常工作。 - razvanone

0

我也曾经为了让插件能够在Java 11上正常工作而苦苦挣扎。 尝试详细列出插件的依赖关系以解决这个问题:

<build>
    <pluginManagement>
        <plugins>
            <plugin>
                <groupId>org.apache.cxf</groupId>
                <artifactId>cxf-xjc-plugin</artifactId>
                <version>3.2.3</version>
                <dependencies>
                    <dependency>
                        <groupId>com.sun.xml.bind</groupId>
                        <artifactId>jaxb-xjc</artifactId>
                        <version>${jaxb-api.version}</version>
                    </dependency>
                    <!-- Java Architecture for XML Binding (JAXB), Java 11+ support -->                                         
                    <dependency>
                        <groupId>javax.xml.bind</groupId>
                        <artifactId>jaxb-api</artifactId>
                        <version>${jaxb-api.version}</version>
                    </dependency>                       
                    <dependency>
                        <groupId>com.sun.xml.bind</groupId>
                        <artifactId>jaxb-impl</artifactId>
                        <version>${jaxb-api.version}</version>
                    </dependency>
                    <dependency>
                        <groupId>com.sun.xml.bind</groupId>
                        <artifactId>jaxb-core</artifactId>
                        <version>${jaxb-api.version}</version>
                    </dependency>
                    <!-- JavaBeans Activation Framework (JAF), Java 11+ support -->
                    <dependency>
                        <groupId>javax.activation</groupId>
                        <artifactId>javax.activation-api</artifactId>
                        <version>${jaf-api.version}</version>
                    </dependency>       
                    <!-- Java API for XML Web Services (JAX-WS), Java 11+ support -->
                    <dependency>
                        <groupId>javax.xml.ws</groupId>
                        <artifactId>jaxws-api</artifactId>
                        <version>${jaxws-api.version}</version>
                    </dependency>
                </dependencies>                 
            </plugin>               

..一无所获。 当我升级到插件的3.2.3版本时,问题消失了 (同时等待3.3.0版本,如此描述:https://issues.apache.org/jira/browse/CXF-7852)。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接