现象: 遇到了一个比较老的项目。项目能启动起来。但是maven构建的时候总是会去加载一个仓库中不存在的废弃的jar包版本;项目中又有别的jar包也依赖了这个jar。然后还有好多项目模块也依赖这个jar。所以mave视图里面一片红。
笔者又是个洁癖的码农。怎么能忍呢。结果就去尝试看看哪个jar包依赖了这个不存在的jar。结果通过分析依赖关系找了半天,发现所有依赖这个问题包的jar的pom里面的版本又都不是这个有问题的版本;然后试着排包。排除了之后发现还是不行。依旧会去加载这个包。当时挺郁闷的。后来把项目的pom简化到只有两个包,然后发给了别人帮忙一起分析。结果有一个小伙伴一下子就找到问题了。其实是项目中依赖了一个父pom依赖管理(dependencyManagement)里面引用了这个jar的,这样所有子项目就都会使用这个父里面的版本了。但是这个父pom本地代码又搜不到。
还好后来发给别人看了。自己已经是思维定势了。在庞大的项目结构里面迷失了方向,分析半天后还是以为还有什么别的包里面依赖了这个包。然后把项目精简到只有几个依赖发给别的伙伴直接就找到了是在父模块中。果然人多力量大。
解决方案就是在自己的项目中通过依赖管理(dependencyManagement)把父项目中的那个有问题的版本给覆盖掉。问题得以解决;