97、jar包加入本地仓库

mvn install:install-file -Dfile=/Users/KXY/Software/jars/taobao-sdk.jar -DgroupId=com.taobao -DartifactId=taobao-sdk -Dversion=1.0.0 -Dpackaging=jar

# 卸载
~/.m2/repository/目录删除相关文件夹

98、dependency标签scope和optional详解

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-tomcat</artifactId>
  <scope>provided</scope>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-devtools</artifactId>
  <!-- 不会传递到子模块中 -->
  <optional>true</optional>
</dependency>
# scope的值有以下几种配置:

compile
# 默认就是compile。compile表示被依赖项目需要参与当前项目的编译,当然后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去。在部署的时候将会打包到lib目录下,项目在编译,测试,运行阶段都需要

test
# test表示依赖项目仅仅参与测试相关的工作,在编译和运行环境下都不会被使用,更别说打包了。

runtime
# runntime仅仅适用于运行环境,在编译和测试环境下都不会被使用

provided
# provided适合在编译和测试的环境,和compile很接近,但是provide仅仅需要在编译和测试阶段,同样provide将不会被打包到lib目录下。

system
# 从参与度来说,也provided相同,不过被依赖项不会从maven仓库抓,而是从本地文件系统拿,一定需要配合systemPath属性使用。

scope的依赖传递

A–>B–>C。当前项目为A,A依赖于B,B依赖于C。知道B在A项目中的scope,那么怎么知道C在A中的scope呢?答案是:
当C是test或者provided时,C直接被丢弃,A不依赖C;
否则A依赖C,C的scope继承于B的scope。

为什么需要区分这些scope

可以用来限制dependency的范围可以在不同的环境下打包不同的jar包,比如junit测试类的jar包不需要在编译运行的时候,就可以设置scope为test。

最后还有一个true是什么意思,怎么用的呢?

例如上面的例子,true的话,其他项目依赖此项目也不会进行传递,只能本项目使用。

99、maven命令新建Java项目

mvn archetype:generate -DgroupId=cn.kxy -DartifactId=HelloWorld -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false

Q.E.D.


行走在天地间自由的灵魂