Maven最佳实践之一个好的parent依赖基础
使用parent 控制依赖版本是很常见的事。
如果你有过控制依赖版本的这种经历,你可能就会遇到过第三方版本之间的冲突,本文不介绍如何解决冲突,但是会提供给你一个基本不存在冲突的基础依赖。
得益于 spring ,尤其是 spring boot 对第三方集成提供的 starter。spring boot 对可能用到的第三方依赖提供了很好的版本控制,我们就依靠 spring 提供的 bom 和 dependencies 来实现我们自己的基础依赖。
由于 spring boot 2.0 正式版还没有发布,这里提供的是 spring 4.x 最新版本的依赖,这两个依赖分别如下:
spring framework (bill of materials) » 4.3.12.release
spring boot dependencies » 1.5.8.release
上图只显示部分依赖
这两个依赖搭配的时候,可以通过上面第一个确定你要选择的 spring 版本,然后去 spring boot 这个依赖中选择和 spring 版本对应的版本(spring boot 中有对 spring-core 的依赖)。上面这两个版本就是目前(2017-11-05)最新的版本。
依据这两个依赖,我们创建一个基础的依赖如下:
<?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> <groupid>tk.mybatis</groupid> <artifactid>spring-dependencies</artifactid> <packaging>pom</packaging> <version>4.3.12.release</version> <name>基础依赖版本管理</name> <properties> <springframework.version>4.3.12.release</springframework.version> <springboot.version>1.5.8.release</springboot.version> </properties> <dependencymanagement> <dependencies> <!-- 统一管理spring依赖 --> <dependency> <groupid>org.springframework</groupid> <artifactid>spring-framework-bom</artifactid> <version>${springframework.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--通过spring boot管理其他第三方版本--> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-dependencies</artifactid> <version>${springboot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--其他--> </dependencies> </dependencymanagement> </project>
注意两个依赖都是添加在 dependencymanagement 中,并且指定 <type>pom</type> 和 <scope>import</scope>,import 是 <scope> 中最特别的一个类型,这个类型只能用于这种情况。
同时要注意这两个依赖的顺序,越靠前面优先级越高。
如果你查看上面pom.xml 文件最终生成的 effective-pom,就会发现这是一个有 3000 多行的文件,这里面几乎包含了常见的各种依赖,少数不包含在内再额外添加即可。
除了上面的配置外,一个基础的 pom 还可以在增加一些常见插件的配置。下面是一个简单的示例。
<build> <plugins> <plugin> <artifactid>maven-compiler-plugin</artifactid> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build>
指定编译时的 jdk 版本是非常有必要的,尤其是在使用 idea 的情况下,这样可以避免 idea 选择 1.5 作为默认值的一些编译错误。由于不同环境使用的插件不太相同,所以这里只是一个示例,不需要按照这种方式使用。更合理的用法可能是创建一个插件的基础 pom(plugin-pom),然后在上面的的 pom 中设置 parent 为 plugin-pom,这样能满足更多情况下的选择。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接