这篇文章不错:
思考:打包的时候是按照当前项目为标准打包的,那么所有的冲突都会以当前pom为根pom打包。那么,如果jar冲突,会用当前pom的依赖jar。
根据这个文章做了个有趣的实验:
object3
//install 2个版本的object3,1.0和2.0
//1.0版本java代码和pom
public class TestObject3 {
public void test(){
System.out.println("Object3-1.0");
}
}
<artifactId>Object_3</artifactId>
<version>1.0</version>
//2.0
public class TestObject3 {
public void test(){
System.out.println("Object3-2.0");
}
}
<artifactId>Object_3</artifactId>
<version>2.0</version>
object1
public class TestObject1 {
public static void main(String[] args) {
TestObject1 testObject1 = new TestObject1();
testObject1.test();
}
public void test(){
System.out.println("TestObject1-1.0");
TestObject2 testObject2 = new TestObject2();
TestObject3 testObject3 = new TestObject3();
testObject2.test();
testObject3.test();
}
}
<dependency>
<groupId>org.example</groupId>
<artifactId>Object_3</artifactId>
<version>2.0</version>
</dependency>
springboot项目和自带打包插件
@SpringBootApplication
public class DemoApplication {
public static void main(String[] args) {
test();
SpringApplication.run(DemoApplication.class, args);
}
public static void test(){
TestObject1 testObject1 = new TestObject1();
TestObject2 testObject2 = new TestObject2();
testObject1.test();
testObject2.test();
}
}
<dependency>
<groupId>org.example</groupId>
<artifactId>Object_3</artifactId>
<version>1.0</version>
</dependency>
<dependency>
<groupId>org.example</groupId>
<artifactId>Object_1</artifactId>
<version>1.0</version>
</dependency>
可以根据pom看到,springboot项目依赖object3-1.0
object1依赖object3-2.0
testObject1.test()会输出Object3-2.0还是Object3-1.0
最后:可以看到输出的是springboot依赖的那个版本的打印
直接执行object1:
输出的是object1依赖的版本。
总结:不同模块的依赖最好统一,你想,如果object3的1.0和2.0有一个方法2.0有,1.0没有,又刚好object1用到了,那spring项目将会直接报错。
结论:打包的时候按照,文章中的“单个Pom树的依赖竞争”章节,以打包执行的pom为参考打的包。