首页 > 解决方案 > 如何递归更新 pom.xml 中的依赖版本

问题描述

我正在开发使用 maven 的开源插件。没有父子层次结构,当前工作目录中的所有 maven 项目都是相互独立的,它们都托管在 git 上。我所有的插件都有一个共同的依赖项,我现在手动更新它。

<dependencies>
  <dependency>
    <groupId>org.projectA</groupId>
    <artifactId>agent-api</artifactId>
    <version>0.13.4-SNAPSHOT</version>
    <scope>provided</scope>
  </dependency>
  ..............
 <dependencies>

有人可以帮助我是否有maven办法更新依赖版本以递归更新当前工作目录版本中的所有项目powershellgit0.13.5-SNAPSHOTgroupIdorg.projectA

标签: javagitpowershellmavenpom.xml

解决方案


如果您的数据在 xml 文件中,您可以在 PowerShell 中执行此操作,方法是从 xml 文件中读取数据并将其存储为 XML 文档对象。您可以结合使用它Get-ChildItem来查找指定路径中的所有 xml 文件。

$xml = [xml](Get-Content pom.xml)
$xml.dependencies.dependency.where({$_.groupId -eq "org.projectA"}) |
   ForEach-Object {
      $_.version="0.13.5-SNAPSHOT"
   }
$xml.Save("c:\temp\pom-updated.xml")

在上面的示例中,我正在从源文件 pom.xml 中读取 xml 数据。然后将更新的 xml 对象存储在 pom-updated.xml 中。我相信该Save()方法需要输出文件的完整路径。

要遍历所有文件并使用更新的值覆盖文件,您可以执行以下操作:

foreach ($xmlFile in (Get-ChildItem -Path "c:\temp\test1" -recurse -include "*.xml" -File)) {
    $xml,$xmlNodes = $null
    $xml = [xml](Get-Content $xmlFile.fullname)
    $xmlNodes = $xml.SelectNodes("//dependency").where({$_.groupId -eq "org.projectA"})
    if ($xmlNodes) {
        $xmlNodes | ForEach-Object { $_.version = "0.13.5-SNAPSHOT" }
        $xml.Save($xmlFile.fullname)
    }
}

推荐阅读