maven 依赖和坐标
1、maven 坐标由groupId、artifactId、packaging、version、classifier定义。
2、classifier 用来帮助定义构建输出的一些附属构件。如,*javadoc.jar,*sources.jar。不能直接定义项目的classifier。
3、maven packaging 包括 jar、war、pom、maven-plugin、ear等。
4、依赖标签及其子标签
<dependency>
<groupId></groupId>
<artifactId></artifactId>
<version></version>
<type></type>
<scope></scope>
<optional></optional>
<exclusions>
<exclusion>
</exclusion>
</exclusions>
</dependency>
依赖范围
compile 默认。表示该依赖对主代码和测试都有效。
test 表示该依赖只对测试有效。即测试代码中 import JUnit 没有问题,但在主代码中 import JUnit就会造成编译错误。该依赖只会被加入到测试代码的classpath中。
provided 已提供依赖。编译、测试有效,运行时无效。如servlet-api,编译和测试时需要;但在运行时,由于容器已提供,不再需要。
runtime 运行时有效。测试和运行时有效,但在编译时不需要。如JDBC驱动实现,编译时只需要JDK提供的JDBC的接口;只有在执行测试和运行项目的时候才需要具体的JDBC驱动。
system 谨慎使用。
排除依赖
情景1:当前项目依赖了一个第三方依赖,但这个第三方依赖又依赖了另外一个SNAPSHOT版本的依赖,那么这个不稳定版本的依赖会影响到当前版本的稳定性。
情景2:Hibernate依赖 Sun JTA API,但由于版权的原因,该类库不存在于中央仓库,而Apache Geronimo 有一个对应的实现。这时就可以排除 Sun JTA API,再显示声明依赖 Apache Geronimo的 JPA API 实现。
<dependency>
<groupId>xxx</groupId>
<artifactId>xxx</artifactId>
<version>5.1.30</version>
<exclusions>
<exclusion>
<groupId>xxx-zzz</groupId>
<artifactId>zzz</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>xxx-zzz</groupId>
<artifactId>zzz</artifactId>
<version>1.1.1</version>
</dependency>
exclusion 可以有多个;声明exclusions时不需要版本号。
可选依赖
A—>B、B->X(可选)、B->Y(可选),那么X和Y都不会传递给A。
项目B实现了两个特性,特性一依赖X,特性二依赖Y,而这两个特性是互斥的。
比如一个持久层构件支持多种数据库,它需要多个数据库的驱动程序,但在使用它的时候,只会依赖一个数据库。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.30</version>
<optional>true</optional>
</dependency>
<dependency>
<groupId>myOracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0</version>
<optional>true</optional>
</dependency>
上面这两个依赖只对当前项目有效,当其它构件依赖当前构件时它们不会被传递。
其它构件依赖当前构件后,前者需要在其pom文件里显示声明其中一个。
理想情况下,不要使用可选依赖,写两个构件,分别实现两个特性。
依赖的传递性
比如当前项目依赖org.springframework:spring-core:2.5.6,而spring-core又依赖commons-logging,这时commons-logging就成为当前项目的依赖。
spring-core对commons-logging的依赖,可以在本地仓库里查看spring-core-x.x.x.pom看到。
依赖范围对传递性依赖的影响
当第二依赖的范围是compile时,依赖传递,传递依赖的范围和第一依赖的范围一致;当第二依赖范围是test的时候,依赖不会传递;当第二依赖范围是provided,只有第一依赖范围也是provided时,依赖传递,并且传递依赖的范围也是provided;当第二依赖范围是runtime,依赖传递,第一依赖是compile时,传递依赖是runtime,其它的都和第一依赖相同。
依赖调解
第一原则,就近原则:A->B->C->X(1.0)、A->D-X(2.0)
第二原则,pom中依赖顺序:A->B->X(1.0)、A->D-X(2.0)
优化依赖
mvn dependency:list
mvn dependency:tree
mvn dependency:analyze
Used undeclared dependencies,项目使用到但没有显示声明的。
Unused declared dependencies,项目中没有使用到但显示声明的。
Used undeclared dependencies风险:当前项目直接使用依赖A,比如通过import声明引入并使用,而A是传递依赖,当升级直接依赖时,相关传递依赖的版本也可能变化,比如A的一个接口改变,于是当前项目无法编译,不易排查错误。
Unused declared dependencies要注意:不应该简单的直接删除声明,要仔细分析。由于dependency:analyze只分析编译主代码和编译测试代码需要用到的依赖,一些执行测试和运行时需要的依赖它就发现不了。
maven 依赖和坐标的更多相关文章
- Maven学习笔记—坐标和依赖
Maven的坐标和依赖 1 Maven坐标 1.1 什么是Maven坐标 Maven坐标:世界上任何一组构件都可以使用Maven坐标来唯一标识,Maven坐标的元素包括groupId.artifact ...
- maven学习(九)——maven中的坐标、依赖以及仓库
一.Maven坐标 1.1.什么是坐标? 在平面几何中坐标(x,y)可以标识平面中唯一的一点. 1.2.Maven坐标主要组成 groupId:组织标识(包名) artifactId:项目名称 ver ...
- Maven依赖(转)
相同依赖级别,先加入的先依赖不同依赖级别,级别短的先依赖 version-->SNAPSHOTxxx-里程碑-->SNAPSHOT,alpha,beta,Release(RC),GA()s ...
- Maven依赖解析
本文将记录Maven工程中依赖解析机制,内容包括: Maven依赖基本结构 从仓库解析依赖的机制 依赖传递性解析实例 1. Maven依赖基本结构 上篇文章记录了Maven依赖的聚合与继承,POM中依 ...
- 转:MAVEN依赖的是本地工程还是仓库JAR包?
相信大家都碰见过 maven 配置的依赖或者是 jar 包或者是工程,在开发的过程当中,我们当然需要引入的是工程,这样查看 maven 依赖的文件的时候,就能直接查看到源码. 一.本地工程依赖 举个例 ...
- Maven依赖的是本地工程还是仓库jar包?
相信大家都碰见过maven配置的依赖或者是jar包或者是工程,在开发的过程当中,我们当然需要引入的是工程,这样查看maven依赖的文件的时候,就能直接查看到源码. 一.本地工程依赖 举个例子,其架构如 ...
- maven依赖的描述
maven的坐标和依赖 坐标和依赖,主要涉及的就是pom文件的头部和<dependencies>标签部分(1)pom文件的头部 这里头部不是指pom文件的开头<project> ...
- maven依赖管理
maven依赖管理 1.依赖范围 (依赖相当于java中的import 是否需要导入别的jar包) 使用控制依赖与三种classpath(编译期,测试时期,运行时期)的关系 complie ...
- Maven依赖传递、依赖传递排除、依赖冲突
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6628429.html 一:Maven依赖传递 假如有Maven项目A,项目B依赖A,项目C依赖B.那么我们可 ...
随机推荐
- 解析ASP.NET Mvc开发之查询数据实例 分类: ASP.NET 2014-01-02 01:27 5788人阅读 评论(3) 收藏
目录: 1)从明源动力到创新工场这一路走来 2)解析ASP.NET WebForm和Mvc开发的区别 ----------------------------------------------- ...
- Eclipse *的下载(图文详解)
不多说,直接上干货! 简单了解,Eclipse是绿色软件,下载下来是个压缩包,只需要解压,加上jdk就可以运行了. 相比MyEclipse而言,它是免费的,后者是收费的.各有侧重吧 有很多人用Ecli ...
- C/C++ -- Gui编程 -- Qt库的使用 -- 信号与槽的关联
Qt信号与槽的三种关联方法:1.设计界面关联,编辑信号/槽,自动关联 2.手动关联(1).头文件中定义槽 -----mywidget.h----- #ifndef MYWIDGET_H #define ...
- OpenGL-非实时渲染与实时混合使用(有图有真相)
视频教程请关注 http://edu.csdn.net/lecturer/lecturer_detail?lecturer_id=440 一个朋友在问(我也曾经遇到过这样的事情),尤其是在地理信息上面 ...
- Redis笔记(五):Redis发布订阅
Redis 发布订阅 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息. Redis 客户端可以订阅任意数量的频道. 下图展示了频道 cha ...
- Innosetup新增Wizard Page
Innosetup 新增一个向导页面,让用户选择安装方式 转载于:http://www.docin.com/p-612536939.html 在Innosetup的向导页面中,新增一个页面,提供两种安 ...
- Nodejs学习笔记(十五)—Node.js + Koa2 构建网站简单示例
前言 前面一有写到一篇Node.js+Express构建网站简单示例:http://www.cnblogs.com/zhongweiv/p/nodejs_express_webapp.html 这篇还 ...
- lucene源码分析(1)基本要素
1.源码包 core: Lucene core library analyzers-common: Analyzers for indexing content in different langua ...
- cordova打包APK,SyntaxError: Block-scoped declarations (let, const, function, class) not yet supported outside strict mode ...
javascript 严格模式 第一次接触let关键字,有一个要非常非常要注意的概念就是”javascript 严格模式”,比如下述的代码运行就会报错: let hello = 'hello worl ...
- IE浏览器版本的判断
var userAgent = navigator.userAgent; //取得浏览器的userAgent字符串 && userAgent.indexOf(; //判断是否IE< ...