maven依赖管理

逃离我推掉我的手 2022-02-27 03:50 416阅读 0赞

1、依赖的引入
 使用 dependency 标签指定被依赖 jar 包的坐标:

  1. <dependency>
  2. <groupId>com.atguigu.maven</groupId>
  3. <artifactId>Hello</artifactId>
  4. <version>0.0.1-SNAPSHOT</version>
  5. <scope>compile</scope>
  6. </dependency>

自己的工程,需要使用mvn install安装到本地仓库。
2、scope的分类
 compile
 默认的scope,表示 dependency 都可以在生命周期中使用。而且,这些dependencies 会传递到依赖的项目中。适用于所有阶段,会随着项目一起发布。即依赖的项目会参与到当前项目的编译、运行、测试以及打包发布,是一个比较强的依赖范围。
 test
 表示dependency作用在测试时,不作用在运行时。 只在测试时使用,用于编译和运行测试代码。不会随项目发布。
 runntime
 表示dependency不作用在编译时,但会作用在运行和测试时,如JDBC驱动,适用运行和测试阶段。即是跳过编译阶段, 只参与测试或运行。
 provided
 跟compile相似,但是表明了dependency 由JDK或者容器提供,例如Servlet AP和一些Java EE APIs。这个scope 只能作用在编译和测试时,同时没有传递性。 即该依赖是由系统组件提供的,我们不需要手动添加,它只存在于编译、运行和测试阶段,打包的时候并不会打进去,被剔除了的。
 system
 跟provided 相似,但是在系统中要以外部JAR包的形式提供,maven不会在repository查找它。需通过外部引入,不会在仓库中查找。例如一些特殊的jar我们或通过拷贝jar到web-info/lib下,这些jar就可以配置为system范围。
在这里插入图片描述
3、依赖的传递性
 可以传递的依赖不必在每个模块工程中都重复声明,在最终的工程依赖一次即可。非compile范围的依赖不能传递。所以在各个工程模块中,如果有需要就得重新声明依赖。
在这里插入图片描述
4、依赖的隔断
 设置optional为true,默认为false。false会传递给依赖它的工程;true不会传递给依赖它的工程。

  1. <dependency>
  2. <groupId>sample.ProjectC</groupId>
  3. <artifactId>Project-C</artifactId>
  4. <version>1.0</version>
  5. <scope>compile</scope>
  6. <optional>true</optional>
  7. </dependency>

5、依赖的排除
 使用exclusion排除依赖。

  1. <dependency>
  2. <groupId>com.atguigu.maven</groupId>
  3. <artifactId>HelloFriend</artifactId>
  4. <version>0.0.1-SNAPSHOT</version>
  5. <type>jar</type>
  6. <scope>compile</scope>
  7. <exclusions>
  8. <exclusion>
  9. <groupId>commons-logging</groupId>
  10. <artifactId>commons-logging</artifactId>
  11. </exclusion>
  12. </exclusions>
  13. </dependency>

6、依赖的原则
是为了解决 jar 包冲突 。有两个原则:
(1)、路径最短者优先
在这里插入图片描述
(2)、路径相同时先声明者优先
在这里插入图片描述
7、统一依赖版本
对同一个框架的一组 jar 包最好使用相同的版本。为了方便升级框架,可以将 jar 包的版本信息统一。
(1)、统一声明版本号。其中 atguigu.spring.version 部分是自定义标签。

  1. <properties>
  2. <atguigu.spring.version>4.1.1.RELEASE</atguigu.spring.version>
  3. </properties>

(2)、引用前面声明的版本号

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework</groupId>
  4. <artifactId>spring-core</artifactId>
  5. <version>${atguigu.spring.version}</version>
  6. </dependency>
  7. </dependencies>

properties标签的其他用法

  1. <properties>
  2. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  3. </properties>

发表评论

表情:
评论列表 (有 0 条评论,416人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Maven依赖管理

    定义maven坐标 每个maven工程都需要定义本工程的坐标,坐标是maven对jar包的身份定义。 <!--项目名称,定义为组织名+项目名,类似包名-->

    相关 maven依赖机制及依赖管理

    maven依赖机制及依赖管理 依赖性传递: 依赖调解: 当项目中出现多个版本构件依赖的情形,依赖调解决定最终应该使用哪个版本。当然,你也可以在项目POM文件中

    相关 Maven依赖管理大全

    大家都知道随着业务的进展,项目会变得越来越多,这个时候如果没有一个统一的依赖管理中心,就会有很多问题发生。 如果没有依赖管理中心,会发生哪些问题呢? 1. 项目的依赖会有

    相关 Maven 依赖管理

    Maven 依赖管理 Maven 一个核心的特性就是依赖管理。当我们处理多模块的项目(包含成百上千个模块或者子项目),模块间的依赖关系就变得非常复杂,管理也变得很困难。针...