我怎样才能看到有效pom(在Maven中)的哪些部分来自哪里?

Duf*_*uff 9 debugging dependencies pom.xml maven parent-pom

我正在Maven的一个项目上工作,我正在努力了解有效pom中某些设置的来源.我想追溯,所以我可以找出哪些pom文件需要更改.我修改了我的父pom,我的settings.xml文件,以及任何其他似乎发挥作用的pom,但我想要更改的设置仍然存在于有效的pom中.

有没有办法看到有效pom的哪些部分来自哪里?或者,我是否至少可以看到进入有效pom的pom文件的"依赖"链(如果你愿意的话)?

基本上我有一个类似于这个问题的问题:如何从有效POM中删除存储库,但是如果有一种方法可以向后追踪那将真正帮助我.

谢谢!

小智 7

使用 Maven 插件

从 maven-help-plugin 版本 3.2.0 开始,新verbose标志已添加到effective-pom目标中,它将向您显示此信息。设置verbosetrue将为输出中指向源 POM 文件的每一行添加注释。输出不会显示完整的依赖关系链,但它包含源文件的组 ID、工件 ID、版本和行号。

您可以通过执行以下 Maven 命令生成详细的有效 POM(确保使用 3.2.0 或更高版本的 maven-help-plugin):

mvn org.apache.maven.plugins:maven-help-plugin:3.2.0:effective-pom -Dverbose=true
Run Code Online (Sandbox Code Playgroud)

如果我们将其应用到一个继承自父 pom 的简单 Maven 项目,如下例所示:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.4.0</version>
  </parent>

  <groupId>org.mycompany</groupId>
  <artifactId>myproject</artifactId>
  <version>1.0-SNAPSHOT</version>

  <name>My Project</name>

  <properties>
      <a-property>hello world</a-property>
  </properties>
</project>
Run Code Online (Sandbox Code Playgroud)

然后输出将如下所示(请注意每行末尾的附加 XML 注释):

<?xml version="1.0" encoding="Cp1252"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 5 -->
  <parent>
    <groupId>org.springframework.boot</groupId>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 8 -->
    <artifactId>spring-boot-starter-parent</artifactId>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 9 -->
    <version>2.4.0</version>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 10 -->
  </parent>
  <groupId>org.mycompany</groupId>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 13 -->
  <artifactId>myproject</artifactId>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 14 -->
  <version>1.0-SNAPSHOT</version>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 15 -->
  <name>My Project</name>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 17 -->
  <description>Parent pom providing dependency and plugin management for applications built with Maven</description>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 12 -->
  <url>https://spring.io/projects/spring-boot/myproject</url>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 21 -->
  <licenses>
    <license>
      <name>Apache License, Version 2.0</name>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 24 -->
      <url>https://www.apache.org/licenses/LICENSE-2.0</url>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 25 -->
    </license>
  </licenses>
  <developers>
    <developer>
      <name>Pivotal</name>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 30 -->
      <email>info@pivotal.io</email>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 31 -->
      <organization>Pivotal Software, Inc.</organization>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 32 -->
      <organizationUrl>https://www.spring.io</organizationUrl>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 33 -->
    </developer>
  </developers>
  <scm>
    <url>https://github.com/spring-projects/spring-boot/myproject</url>  <!-- org.springframework.boot:spring-boot-starter-parent:2.4.0, line 37 -->
  </scm>
  <properties>
    <a-property>hello world</a-property>  <!-- org.mycompany:myproject:1.0-SNAPSHOT, line 20 -->
Run Code Online (Sandbox Code Playgroud)

使用 Apache NetBeans

另一种选择是使用 Apache NetBeans IDE,它具有通过每行源的链接来注释有效 POM 文件的功能。

在 NetBeans IDE 中打开 Maven 项目的 pom.xml 文件,然后单击编辑器顶部的“Effective”选项卡。通过将鼠标悬停在编辑器左侧的注释上,您可以查看源代码,也可以单击它以立即转到引用的 POM 文件: Apache NetBeans 中有效 POM 的来源


use*_*849 4

这个答案描述了创建有效 POM 的各个部分。

您可以尝试此答案的变体来查看 POM 层次结构(您所谓的“依赖关系”链)。将此配置添加到父 POM<build><plugins>部分(暂时?)以查看它。

<plugin>
    <groupId>org.codehaus.gmaven</groupId>
    <artifactId>groovy-maven-plugin</artifactId>
    <version>2.0</version>
    <executions>
        <execution>
            <id>echo-build-environment</id>
            <phase>validate</phase>
            <goals>
                <goal>execute</goal>
            </goals>
            <configuration>
                <source>
                <![CDATA[
                log.info("POM Hierarchy")
                def rootPom = project;
                while (rootPom.parent != null) {
                    log.info(rootPom.groupId + ':' + rootPom.artifactId + ':' + rootPom.version)
                    rootPom = rootPom.parent;
                }
                log.info(rootPom.groupId + ':' + rootPom.artifactId + ':' + rootPom.version)
                ]]>
                </source>
            </configuration>
        </execution>
    </executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)

(注意,在纯 Groovy 中,上面的 log.info 行可以写为

"${rootPom.groupId}:${rootPom.artifactId}:${rootPom.version}"
Run Code Online (Sandbox Code Playgroud)

Groovy 将这些称为GStrings。我知道 gmaven 插件处理 GString 的方式与普通 Groovy 略有不同,但现在没有时间查找详细信息,因此在示例中使用了常规字符串连接。)