10

我有一个基于 Maven 的项目,我尝试添加一些由“jaxb2-maven-plugin”Maven 插件自动生成的 JAXB 类。但是,我的第一次剪辑让我处于循环依赖循环中:

  • 因为这些 JAXB 类尚未生成,所以我引用它们的其他来源有编译错误。
  • 因为那些其他源有编译错误,所以不会生成这些 JAXB 类。

似乎有两种明显的可能性可以解决这个问题:

  1. 注释掉损坏的引用,以便项目构建和 JAXB 类自动生成。然后将这些生成的源代码从 复制/target/src/main/java中,这样对它们的引用就不会导致编译错误。
  2. 创建一个完全独立的项目,只包含 JAXB 的东西。将其作为依赖项包含在我的主项目中。

我在这里错过了什么吗?选项#1 似乎完全荒谬......这不可能是人们使用 JAXB 的方式。选项#2 似乎更合理,但仍然相当低效和麻烦。为了使用 JAXB,我真的必须承担一个完全独立的项目的开销吗?

开发人员是否可以使用更优雅的方法在 Maven 插件生成它们的同一项目中引用 JAXB 生成的类?

更新: 根据要求,这是我的 POM 的相关部分:

<build>
    <plugins>
        <plugin>
            <!-- configure the compiler to compile to Java 1.6 -->
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
            </configuration>
        </plugin>       
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>jaxb2-maven-plugin</artifactId>
            <version>1.4</version>
            <executions>
                <execution>
                    <phase>generate-sources</phase>
                    <goals>
                        <goal>xjc</goal>
                    </goals>
                </execution>
            </executions>
            <configuration>
                <!-- The name of your generated source package -->
                <packageName>com.mypackage</packageName> 
            </configuration>
        </plugin>
    </plugins>  
</build>

当我运行时,我确实看到在子目录mvn clean package下生成了我的 JAXB 源。/target但是,这些生成的源不会自动添加到编译阶段的类路径中。

解决后更新: 事实证明,我的编译问题更多地与我在 Eclipse 中运行的事实有关,并且它的 Maven 集成与“jaxb2-maven-plugin”有一些问题。有关该问题及其解决方案的更多详细信息,请参阅此 StackOverflow 问题。

4

3 回答 3

9

你是如何配置你的 jaxb maven 插件的?通常它在生成源生命周期中运行,该生命周期在编译生命周期之前。因此,当您自己的代码被编译时,您的 JAXB 生成的类应该已经存在,Maven 将它们放在目标/生成源中,并将该文件夹放在类路径中。

编辑:这是我在工作中使用的代码(并且按预期工作):

<plugin>
            <groupId>com.sun.tools.xjc.maven2</groupId>
            <artifactId>maven-jaxb-plugin</artifactId>
            <executions>
                <execution>
                    <phase>generate-sources</phase>
                    <goals>
                        <goal>generate</goal>
                    </goals>
                </execution>
            </executions>
            <configuration>
                <schemaDirectory>src/main/resources/<companyname>/xsd</schemaDirectory>
                <includeSchemas>
                    <includeSchema>retrieval.xsd</includeSchema>
                    <includeSchema>storage.xsd</includeSchema>
                </includeSchemas>
            </configuration>
        </plugin>

显然我们使用了另一个 jaxb 插件......(另请参阅此线程:Difference of Maven JAXB plugins)。

于 2012-08-15T15:21:20.803 回答
6

我建议您将 jaxb 生成的类(api)和您的 BL 类(实现)拆分为 2 个 maven 项目,每个项目具有单独的 pom.xml,主根 pom.xml 具有编译顺序。这样,您将能够构建 api.jar,然后 maven 将其安装在本地 repo 中,然后您可以将其用作实现的依赖项。所以它看起来像:

-API\
--pom.xml - for api, jaxb generation
-IMPL\
--pom.xml - for impl, api dependency is here
pom.xml - main pom.xml with references to the projects above
于 2012-08-15T19:15:21.897 回答
3

也许尝试使用maven-jaxb2-plugin

<plugin>
    <groupId>org.jvnet.jaxb2.maven2</groupId>
    <artifactId>maven-jaxb2-plugin</artifactId>
    <version>0.8.2</version>
    <executions>
        <execution>
            <goals>
                <goal>generate</goal>
            </goals>
        </execution>
    </executions>
</plugin>

不过,dfuse 的答案是正确的。任何一个插件都应该在编译之前生成源代码,源代码生成的结果将在类路径中。我用两个插件对此进行了测试。您是否可以发布您的架构,或者至少发布您的代码未能在类路径上获取的类型的架构?

于 2012-08-15T18:21:39.727 回答