上次这边朋友问我一个问题,就是他们在pom.xml中的dependency中,看到有一些是<scope>provided</scope>的情况,比如如下:

双击代码全选
1
2
3
4
5
6
<dependency>
   <groupId>com.liferay.portal</groupId>
   <artifactId>portal-impl</artifactId>
   <version>6.1.0</version>
   <scope>provided</scope>
</dependency>

他们问我scope在何种情况下要设置为provided,以及和scope设置为compile的区别。

解释:

其实这个问题很简单。

对于scope=compile的情况(默认scope),也就是说这个项目在编译,测试,运行阶段都需要这个artifact对应的jar包在classpath中。

而对于scope=provided的情况,则可以认为这个provided是目标容器已经provide这个artifact。换句话说,它只影响到编译,测试阶段。在编译测试阶段,我们需要这个artifact对应的jar包在classpath中,而在运行阶段,假定目标的容器(比如我们这里的liferay容器)已经提供了这个jar包,所以无需我们这个artifact对应的jar包了。

听起来很玄乎,对吧,其实一点也不难理解。举个scope=provided的例子。

比如说,假定我们自己的项目ProjectABC 中有一个类叫C1,而这个C1中会import这个portal-impl的artifact中的类B1,那么在编译阶段,我们肯定需要这个B1,否则C1通不过编译,因为我们的scope设置为provided了,所以编译阶段起作用,所以C1正确的通过了编译。测试阶段类似,故忽略。

那么最后我们要吧ProjectABC部署到Liferay服务器上了,这时候,我们到$liferay-tomcat-homewebappsROOTWEB-INFlib下发现,里面已经有了一个portal-impl.jar了,换句话说,容器已经提供了这个artifact对应的jar,所以,我们在运行阶段,这个C1类直接可以用容器提供的portal-impl.jar中的B1类,而不会出任何问题。

实际插件的行为:

刚才我们讲述的是理论部分,现在我们看下,实际插件在运行时候,是如何来区别对待scope=compile和scope=provided的情况的。

做一个实验就可以很容易发现,当我们用maven install生成最终的构件包ProjectABC.war后,在其下的WEB-INF/lib中,会包含我们被标注为scope=compile的构件的jar包,而不会包含我们被标注为scope=provided的构件的jar包。这也避免了此类构件当部署到目标容器后产生包依赖冲突。

Maven中<dependencies>节点和<dependencyManagement>节点的区别

解释如下:

Maven 使用dependencyManagement 元素来提供了一种管理依赖版本号的方式。通常会在一个组织或者项目的最顶层的父POM 中看到dependencyManagement 元素。使用pom.xml 中的dependencyManagement 元素能让
所有在子项目中引用一个依赖而不用显式的列出版本号。Maven 会沿着父子层次向上走,直到找到一个拥有dependencyManagement 元素的项目,然后它就会使用在这个dependencyManagement 元素中指定的版本号。

1 .使用项目继承

利用项目继承可以将结构信息,部署信息,共同的依赖信息放置在单一的位置。在每个工程的 pom 中:

[...]

<parent>

<groupId>org.apache.maven.proficio</groupId>

<artifactId>proficio</artifactId>

<version>1.0-SNAPSHOT</version>

</parent>

[...]

这使得项目的 pom 可以继承顶层 pom 中的定义,检查顶层 pom 的 dependencies 部分:

<project>

[...]

<dependencies >

<dependency >

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.7</version>

<scope>test</scope>

</dependency >

</dependencies >

[...]

</project>

在各个子模块的 pom 中没有对 Junit 依赖的定义,但是从顶层 pom 中继承了依赖的定义。

为了看清楚可以在一个子模块 pom 所在目录下,执行命令

#mvn help:effective-pom

可以看到最终起效果的 pom ,这在找错时很有效。

2 .管理依赖

在 pom 中指明 dependency management 元素的方式 maven 结合项目继承来管理依赖。在多模块应用中,可能多个子项目会有共同的依赖。此时为了正确运行,必须让所有的子项目使用依赖项的同一版本。必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的成果。因此,应在顶层的 pom 中定义共同的依赖关系。

在 Proficio 应用的顶层 pom 中的 dependency management 段如下:

<dependencyManagement>

<dependencies >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-model</artifactId>

<c>${project.version}</version>

</dependency >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-api</artifactId>

<version>${project.version}</version>

</dependency >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-core</artifactId>

<version>${project.version}</version>

</dependency >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-store-memory</artifactId>

<version>${project.version}</version>

</dependency >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-store-xstream</artifactId>

<version>${project.version}</version>

</dependency >

<dependency >

<groupId>org.codehaus.plexus</groupId>

<artifactId>plexus-container-default</artifactId>

<version>1.0-alpha-9</version>

</dependency >

</dependencies >

</dependencyManagement>

注意 ${project.version} 变量指的是应用的 version 。

顶层 pom 中的 dependencies 与 dependencyManagement 中的 dependencies 元素有一个重要的区别:

dependencyManagement 中的 dependencies 元素只表明依赖项版本的优先选择,并不影响项目的依赖项;而 dependencies 元素则影响项目的依赖项。

检查 Proficio api 模块的 pom:

<project>

<parent>

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio</artifactId>

<version>1.0-SNAPSHOT</version>

</parent>

<modelVersion>4.0.0</modelVersion>

<artifactId>proficio-api</artifactId>

<packaging>jar</packaging>

<name>Proficio API</name>

<dependencies >

<dependency >

<groupId>com.devzuz.mvnbook.proficio</groupId>

<artifactId>proficio-model</artifactId>

</dependency >

</dependencies >

</project>

其中没有指明依赖项的版本信息,在顶层 pom 中的 dependencyManagement 中表明其优选的版本是 ${project.version} 即 1.0-SNAPSHOT 。为使其模块 pom 完整,其版本信息会注入其中。

只有当 外层的dependencies 元素中没有指明版本信息时, dependencyManagement中的 dependencies 元素才起作用。

注意:一个是项目依赖,一个是多模块maven项目时候的依赖管理控制的。

maven中DependencyManagement和Dependencies相关推荐

  1. cmenu 隐藏子项中的一个子项_区分Maven中dependencyManagement与dependencies的作用

    导读:使用maven是为了更好的帮项目管理包依赖,maven的核心就是pom.xml.而maven中有许多的标签,下面我们主要讨论parent.dependencies与dependencyManag ...

  2. Maven中dependencyManagement的使用

    本文来说下Maven中dependencyManagement的使用 文章目录 dependencyManagement的使用 dependencyManagement的意义 dependencyMa ...

  3. Maven中dependencyManagement标签和dependencies的区别

    今天在maven的pom文件中看到了dependencyManagement标签,用法如下: <dependencyManagement><dependencies><d ...

  4. Maven中的dependencyManagement 意义

    1.在Maven中dependencyManagement的作用其实相当于一个对所依赖jar包进行版本管理的管理器. 2.pom.xml文件中,jar的版本判断的两种途径 1:如果dependenci ...

  5. Maven 梳理 - Maven中的dependencyManagement 意义

    1.在Maven中dependencyManagement的作用其实相当于一个对所依赖jar包进行版本管理的管理器. 2.pom.xml文件中,jar的版本判断的两种途径 1:如果dependenci ...

  6. maven 中 pom.xml 配置文件标签说明,dependencyManagement和dependencies区别

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 参考:http://zhaoshijie.iteye.com/blog/2094478 http:/ ...

  7. maven 中 dependencies 与 dependencyManagement 的区别

    前言 当前的团队工程项目是一个 maven 工程,里面有多模块,包含了父 pom 与子 pom.而在父 pom 中,我见到了 dependencyManagement 这个东西.我们知道一个 mave ...

  8. Maven 父pom中dependencyManagement版本优先级高于传递依赖版本

    当使用了传递依赖,也就是使用了没有显示声明的依赖时,如果继承的<dependencyManagement/>中声明了使用的传递依赖的版本,那么最终使用的依赖是<dependencyM ...

  9. 获取公司的maven库 和 idea maven 中Projects Settings的Libraries中正常,但是在Maven Projects中Dependencies一直出现红线的解决办法

    一.获取公司的maven库. (1)我点击 Maven Projects 的 设置(如果idea页面上没有Maven Projects 这个框,那就去view->Tool Windows-> ...

最新文章

  1. Coursera Machine Learning 作业提交问题
  2. 数据算法-K Means
  3. Angular开发模式下的setNgReflectProperties函数
  4. 作业帮电脑版在线使用_应届生应聘作业帮的在线辅导老师
  5. urllib2 request 模拟伪装浏览器
  6. SQL PASS西雅图之行——University of Washington篇
  7. java动态数组储存敌机_如何使用参数通过graphql将动态数组字符串存储为neo4j中的节点属性?...
  8. 零延时RS-485接口电路的设计与应用
  9. .Net Core Win2008R2 运行环境问题 502.5
  10. 软考网络工程师好考吗?怎么备考?
  11. 磅 英寸 厘米 dpi 像素
  12. 05、Flutter FFI 结构体
  13. 显示器分辨率如何选择,高清,1080P,2k,4k最舒服的点距
  14. 打印机与计算机接口大多数,打印机接口-西北师范大学.PPT
  15. xml与json格式互转
  16. 计算机换内存条解决方案
  17. 实现用友U8+与旺店通ERP数据同步
  18. 人脸识别数据集-Glint360K
  19. 在GitLab上创建Project完成功能步骤
  20. 多益面试题简答题和编程题解析

热门文章

  1. 鲸探发布点评:7月26日发售
  2. 专利申请模板各个内容的例子
  3. 如何制作U盘Linux 与WinPE启动
  4. Fedora或CentOS运行dnf update报错
  5. 白话空间统计之二十五:空间权重矩阵(四)R语言中的空间权重矩阵(2)
  6. 2022年第十三届蓝桥杯python组决赛
  7. 前台开发技术那些事儿
  8. 一键部署openvpn服务端和客户端(已写成脚本)
  9. java调用iec61850_通过iec61850协议访问设备数据的一个例子
  10. Android 小案例 -- 计算器