Spring IO Platform简单介绍
Spring IO Platform框架简单来说就是一个版本号兼容系统,它将常用第三方类库的兼容的版本组织起来。只要我们在项目中引用了Spring IO Platform,就不需要为这些第三方类库设置版本号了,Spring IO Platform会自动帮我们设置所有兼容的版本号。本文参考自官方文档,如果需要查阅详细信息,请直接看原文即可。
引入类库
使用Maven
使用Maven的话,在pom.xml中修改为类似这样的。
<?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>com.example</groupId> <artifactId>your-application</artifactId> <version>1.0.0-SNAPSHOT</version> <!-- 添加以下一段--> <dependencyManagement> <dependencies> <dependency> <groupId>io.spring.platform</groupId> <artifactId>platform-bom</artifactId> <version>Brussels-SR3</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <!-- Dependency declarations --> </project>
或者将设置Spring IO Platform为父项目也行
<?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>com.example</groupId> <artifactId>your-application</artifactId> <version>1.0.0-SNAPSHOT</version> <parent> <groupId>io.spring.platform</groupId> <artifactId>platform-bom</artifactId> <version>Brussels-SR3</version> <relativePath/> </parent> <!-- Dependency declarations --> </project>
设置完成后,以后添加依赖项就不需要指定版本好了。可以像下面这样添加依赖。
<dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <!-- 没有版本号 --> </dependency> </dependencies>
使用Gradle
如果用Gradle的话,就稍微复杂一点了。因为Gradle没有dependencyManagement这么一个功能,所以还需要额外的插件。总之,将build.gradle文件修改为类似这样即可。
buildscript { repositories { jcenter() } dependencies { classpath 'io.spring.gradle:dependency-management-plugin:1.0.0.RELEASE' } } apply plugin: 'io.spring.dependency-management' repositories { mavenCentral() } dependencyManagement { imports { mavenBom 'io.spring.platform:platform-bom:Brussels-SR3' } }
然后,声明依赖就不需要版本号了。
dependencies { compile 'org.springframework:spring-core' }
覆盖版本号
有时候可能需要覆盖Spring IO Platform中的版本号,改为使用我们自己指定的版本号。如果使用Maven的话,在pom.xml文件的properties节点中修改版本号。
<properties> <foo.version>1.1.0.RELEASE</foo.version> </properties>
如果使用Gradle的话,在build.gradle中添加ext属性即可。
ext['foo.version'] = '1.1.0.RELEASE'
或者
ext { foo.version = '1.1.0.RELEASE' }
也可以在gradle.properties文件中设置。
foo.version=1.1.0.RELEASE
已知问题
由于谷歌Guava类库的广泛使用,引用不同的项目时可能存在不兼容情况。这时候需要我们手动指定合适的版本号以保证项目能够正常运行。
如果想详细了解Spring IO Platform的版本号,可以查看官方文档附录。
示例程序
其实这篇文章到这里就可以结束了,因为Spring IO Platform实际上确实也没有多少东西要讲。
这是我的一个小小例子,用Spring IO Platform和Gradle构建的一个Spring MVC程序。下面是对应的build.gradle文件。可以看到由于使用了Spring IO Platform,所以这里的依赖项全部没有指定版本号。
group 'yitian.study' version '1.0-SNAPSHOT' buildscript { repositories { jcenter() } dependencies { classpath 'io.spring.gradle:dependency-management-plugin:1.0.0.RELEASE' } } apply plugin: 'java' apply plugin: 'war' apply from: 'https://raw.github.com/akhikhl/gretty/master/pluginScripts/gretty.plugin' apply plugin: 'io.spring.dependency-management' sourceCompatibility = 1.8 repositories { mavenCentral() jcenter() } dependencies { testCompile group: 'junit', name: 'junit' compile 'org.springframework:spring-webmvc' compile group: 'org.springframework.boot', name: 'spring-boot-starter-logging' } dependencyManagement { imports { mavenBom 'io.spring.platform:platform-bom:Brussels-SR3' } }
从IDE的提示可以看到,所有版本号都由Spring IO Platform正确处理了。
完整的例子在这里,虽然我感觉大部分不需要看这个。
总结
以上就是本文关于Spring IO Platform简单介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
相关文章
浅谈javaSE 面向对象(Object类toString)
下面小编就为大家带来一篇浅谈javaSE 面向对象(Object类toString)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-06-06解决spring中redistemplate不能用通配符keys查出相应Key的问题
这篇文章主要介绍了解决spring中redistemplate不能用通配符keys查出相应Key的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-11-11如何在IDE部署springboot项目(有swagger和无swagger都是一样的)到服务器或者虚拟机上的docke
这篇文章主要介绍了如何在IDE部署springboot项目(有swagger和无swagger都是一样的)到服务器或者虚拟机上的docker,本文给大家分享我的安装历程,需要的朋友可以参考下2023-01-01intelliJ idea 2023 配置Tomcat 8图文教程
这篇文章主要介绍了intelliJ idea 2023 配置Tomcat 8教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-06-06@RequestParam 接收参数的值为null的处理方式
这篇文章主要介绍了@RequestParam 接收参数的值为null的处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11
最新评论