在项目中经常使用 maven 来管理项目,但是有时候对于 maven 的细节还是了解的不是很清楚,因此今天复习下。
maven项目
首先开始建立一个最简单的 maven 项目,其配置如下图:
可以看到最上面一行是 xml 的文件描述符,然后再是 project,在这里引入 xsd 文件。
XSD(XML Schemas Definition)XML Schema,描述了 xml 文档的结构,用于判断其是否符合 xml 的格式要求
然后下面就是 groupId,通常是公司的域名,artifactId 通常指的是项目名称。
Springboot项目
按照官方的指导,在项目中首先引用 spring-boot-starter-parent,修改后的 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>org.example</groupId> <artifactId>maven-test</artifactId> <version>1.0-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.2.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> <finalName>maven-test</finalName> </build> </project>
当准备在启动类上加 @SpringBootApplication 注解的时候,此时 IDEA 会提示找不到这个注解。这是正常的,因为 parent 只是把这个项目的配置和依赖信息统一化了,使得 子pom 就不用关心版本问题,例如在项目中引入spring-boot-starter-web,当配置了 parent 之后,只需要在 子pom 中如下配置:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
那么它的配置信息就会自动的从 parent 中读取。例如刚刚的spring-boot-starter-web信息,它的版本信息如下:
tips:使用命令mvn -Dverbose dependency:tree就可以像这样打印 jar 的依赖
那么 springboot 又是怎样来自动识别版本号的呢,此时就就涉及到了spring-boot-dependencies
spring-boot-dependencies
spring-boot-dependencies 是 spring-boot-starter-parent 的一个 parent,可以在 spring-boot-starter-parent 的 pom 文件中看到。
打开 spring-boot-dependencies 文件,你会发现它里面几乎全部都是一些配置信息,而刚刚的spring-boot-dependencies 版本号就是来自于此。
到目前为止,可以基本理清 springboot 的依赖关系了。
打包
在工程中,随便写一个 controller,然后执行mvn package,此时会在 target 目录下出现一个 jar 包,然后运行 jar 包,正常启动OK。
替换parent
既然 spring-boot-starter-parent 是依赖于 spring-boot-dependencies的,那么可不可以直接将parent 设置为spring-boot-dependencies呢,修改 pom 文件如下:
然后执行mvn package,执行的时候是成功的,但是当你用 java -jar maven-test.jar 的时候,你会发现提示如下:
target java -jar maven-test.jar maven-test.jar中没有主清单属性
原因
首先分析下两个的 maven log。
spring-boot-starter-parent作为parent
spring-boot-dependencies作为parent
可以看到第二次的打包插件是 maven-jar-plugin,也就是说 springboot 的项目一些资源并没有打包进来,查看 spring-boot-maven-plugin 插件,发现它是来自于 spring-boot-starter-parent 里面的,但是在文章的开头部分,是已经手动的将其引入到了 pom 文件,那么修改 parent 以后未执行的话,最有可能就是版本号的缺失导致的,于是修改pom:
<plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.1.11.RELEASE</version> </plugin> </plugins> <finalName>maven-test</finalName>
然后运行mvn package:
[INFO] --- spring-boot-maven-plugin:2.1.11.RELEASE:repackage (repackage) @ maven-test ---
[INFO] Replacing main artifact with repackaged archive
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
你会发现此时打包出来的 jar 文件已经可以运行了。
进阶
那么假设项目已经有了自己的 parent,如果还想用 spring-boot-dependencies 来进行统一的一个全局版本控制,那么有如下的解决办法
在自己的parent中设置parent为 spring-boot-starter-parent,那么根据 maven 的继承属性,所有的 子pom 也就顺带继承了 spring-boot-starter-parent
到此这篇关于Springboot的maven间接依赖的文章就介绍到这了,更多相关Springboot的maven间接依赖内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
我的Junit示例类是
我有一个控制器 服务接口 我想在我的控制器中使用@autowired来使用该服务,但当我运行应用程序时,我得到以下错误 org.springframework.beans.factory.beanCreationException:创建名为“demo application”的bean时出错:注入autowired依赖项失败;嵌套异常为org.SpringFramework.Beans.Facto
主要内容:依赖声明,获取依赖坐标Maven 是一款优秀的依赖管理工具,那么什么是依赖呢? 通俗的说,如果一个 Maven 构建所产生的构件(例如 Jar 文件)被其他项目引用,那么该构件就是其他项目的依赖。 依赖声明 Maven 坐标是依赖的前提,所有 Maven 项目必须明确定义自己的坐标,只有这样,它们才可能成为其他项目的依赖。当一个项目的构件成为其他项目的依赖时,该项目的坐标才能体现出它的价值。 当 Maven 项目需要声
我想知道以下jar的所有传递依赖项: 将经典命令移动到pom。项目定义依赖关系和输入的xml: mvn依赖:树 将显示: 我没看到魔咒父母: 乍一看,mvn命令似乎可以显示非pom类型的依赖项。 有没有一种方法可以精确地显示使jar保持活动状态所需的每个文件? 谢谢
最近,我发现了以下问题: 当我为我的项目设置依赖项管理时,我有一个child-pom,它使用具有依赖项的插件,我想要与在我的依赖项管理中声明的依赖项同步。 在根pom中,我在依赖项管理中声明: 在子pom中,我有一个插件需要gwt-user: 但是,如果我移除gwt-maven-plugin中使用的依赖版本,编译就会失败。 是不是还有别的办法可以实现呢? PS:在maven和maven插件中有一个
问题内容: 我第一次使用Maven时,就陷入了依赖关系。 我使用Eclipse创建了一个Maven项目并添加了依赖项,并且该项目运行正常。 但是当我尝试通过命令行运行它时: 它下载依赖项,成功构建,但是当我尝试运行它时,出现NoClassDefFoundError: 我的是这样的: 谁能帮我? 问题答案: 默认情况下,Maven不会在生成的JAR文件中捆绑依赖项,并且在尝试通过命令行执行JAR文件