当作为依赖项添加到其他项目时,生产jar如何指定自己的依赖项?

时间:2013-01-01 13:32:46

标签: maven netbeans maven-2 maven-3

如果问题标题无法说清楚,请在此详细解释。假设我的一个Maven应用程序的生产jar需要用于我的其他Maven Web应用程序。将该jar添加到我的第二个应用程序Maven依赖项不会添加其传递依赖项。此外,jar本身就是一个应用程序。

一种方法是查看第一个应用程序的POM,并将其添加到另一个应用程序的POM中。但是,当添加到某个项目时,中央Maven jar如何添加自己的传递依赖。

换句话说,如果我将commons-io.jar Maven依赖项添加到我的项目中,它会自动添加其传递依赖项。但是当我将myjar.jar添加为Maven依赖项(scope->系统)时,它不会自动添加其传递依赖项。

我认为我应该将我的第一个应用程序开发为可以在这种情况下使用的其他原型。请告诉我如何进一步。

抱歉这个新手问题。实际上,我是Maven的新手,我已经开始使用Netbeans-embedded-maven来创建应用程序。我非常喜欢Maven简化工作的方式。

edited

似乎我应该更详细地解释一下。所以就是这样。

假设我编写了一个使用A.jar,B.jar,C.jar的程序/应用程序,我的生产输出是X.jar(根据maven默认构建,它显然不包含其他jar)。上面的A,B,C罐子存在于maven中央存储库中,并作为依赖项添加到我的项目中。项目构建jar是X.jar

现在我编写另一个应用程序,其中我将X.jar添加为系统依赖项,现在我想要的是A.jar,B.jar,C.jar自动添加到项目中,因为它们是X的传递依赖项。罐

希望所以我这次已经解释清楚了。如果您之前不理解,请原谅我的写作风格。

一种解决方案是使用类似

之类的东西构建包含其中所有依赖项的X.jar
 <plugin>
            <artifactId>maven-assembly-plugin</artifactId>
            <configuration>
                <archive>
                    <manifest>
                        <addClasspath>true</addClasspath>
                        <mainClass>com.nitinsurana.mlmmaven.Start</mainClass>
                    </manifest>
                </archive>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>make-my-jar-with-dependencies</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

但我正在寻找能够自动添加系统依赖性的传递依赖性的东西。

4 个答案:

答案 0 :(得分:2)

system scope不应该用于将与其他应用程序打包在一起的实际jar依赖项。引自官方文件:

  

范围系统的依赖关系始终可用,并且不会在存储库中查找。它们通常用于告诉Maven有关JDK或VM提供的依赖关系。因此,系统依赖性对于解决现在由JDK提供的工件的依赖性特别有用,但是可以在之前单独下载。典型示例是JDBC标准扩展或Java身份验证和授权服务(JAAS)。

您应该使用默认的compile范围。

答案 1 :(得分:0)

正如其他人所建议的那样,使用(默认)编译范围并为您不需要/不需要的传递依赖添加<exclusions>

请参阅:Maven > Optional Dependencies and Dependency Exclusions

答案 2 :(得分:0)

我已经浏览了@Sean提供的链接,看起来我想要的东西是不可能的。

我可以投票删除这个问题吗?

虽然答案是不能完成的,但是为什么:

Project-A -> Project-B

上图说Project-A依赖于Project-B。当A在其POM中将B声明为可选依赖项时,此关系保持不变。它就像一个普通的构建,其中Project-B将被添加到其类路径中。

Project-X -> Project-A

但是当另一个项目(Project-X)将Project-A声明为其POM中的依赖项时,可选的依赖项生效。您会注意到Project-B未包含在Project-X的类路径中; you will need to declare it directly in your POM in order for B to be included in X's classpath.

取自Official Documentation

答案 3 :(得分:0)

那么,你的X模块是否已被复原?然后,您可以使用mvn clean install在本地安装它,然后在具有所有传递依赖项和compile范围的其他项目中使用它。这种情况很好,直到你在自己的机器上做所有事情。如果您希望与其他人共享代码或配置CI构建,则需要X,其他人可以使用其pom。执行此操作的最佳方法是拥有自己的工件,可从所有其他计算机访问。您在那里安装X并将其与compile范围一起使用,只需要将新的回购添加到pom。

相关问题