1:添加MAVEN_HOME环境变量 值为安装的maven路径,添加系统变量path值为%MAVEN_HOME%\bin
2:mvn compile编译
mvn test 测试
mvn package打包
mvn clean 删除target文件夹
mvn install 安装jar包到本地仓库
mvn package -Dmaven.test.skip=true 跳过测试
3:命令行创建项目
1:mvn archetype:generate -DgroupId=com.cj -DartifactId=webAppDemo -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false
2:mvn archetype:generate 按照提示选择
4:在settings.xml中配置镜像仓库地址
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
5:在settings.xml配置本地仓库地址
<localRepository>/Users/usename/.m2/repository</localRepository>
6:通常会把settings.xml拷贝一份 以防升级maven 覆盖掉
7:maven生命周期
clean清理项目
pre-clean 执行一些需要在clean之前完成的工作
clean 移除所有上一次构建生成的文件
post-clean 执行一些需要在clean之后立刻完成的工作
default构建项目
compile test package install
site生成项目站点
pre-site 执行一些需要在生成站点文档之前完成的工作
site 生成项目的站点文档
post-site 执行一些需要在生成站点文档之后完成的工作,并且为部署做准备
site-deploy 将生成的站点文档部署到特定的服务器上
8:
<modelVersion>4.0.0</modelVersion>当前pom版本
<groupId></groupId>反写公司网址+项目名
<artifactId></artifactId>项目名+模块名
<packaging>jar</packaging>默认是jar包
<version>0.0.1-SNAPSHOT</version>大版本+分支版本+小版本号 SNAPSHOT快照版本,alpha内部测试,beta公测,release 稳定,GA正式发布
<name>demo</name>项目描述名
<description>Demo project for Spring Boot</description>项目描述名
<url></url>项目地址
<developers></developers>开发人员
<organization>
<!--组织的全名-->
<name>demo</name>
<!--组织主页的URL-->
<url>http://www.baidu.com/banseon</url>
</organization> 9:maven 有编译测试运行三个阶段
<scope>compile</scope> 默认的范围,编译测试运行三个阶段都有效
<scope>provided</scope>编译测试阶段都有效
<scope>runtime</scope> 测试运行阶段都有效
<scope>test</scope> 测试阶段都有效
<scope>system</scope>编译测试阶段都有效和provided类似 只是和本机系统有关,可移植性差
<scope>import</scope>
在<dependencyManagement>管理下的dependencies多了一种scope——import。
这种scope仅用于type为"pom"的dependency,其意义为引入该dependency的pom中定义的所有dependency定义。
10:在mavenB项目中引入mavenA项目依赖,通过依赖传递,会将mavenA中的jar包传递进来
如果B中不需要A中的某个jar包就可以使用以下标签:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
<exclusions>
<exclusion>
<artifactId>commons-logging</artifactId>
<groupId>commons-logging</groupId>
</exclusion>
</exclusions>
</dependency>
11:如何修改maven的默认jdk版本
在maven的安装目录找到settings.xml文件,在里面添加如下代码
<profile>
<id>jdk1.6</id>
<activation>
<activeByDefault>true</activeByDefault>
<jdk>1.6</jdk>
</activation>
<properties>
<!-- want to use the Java 8 language features, Default 1.5 -->
<maven.compiler.source>1.6</maven.compiler.source>
<!-- want the compiled classes to be compatible with JVM 1.8, Default 1.5 -->
<maven.compiler.target>1.6</maven.compiler.target>
<!-- Version of the compiler to use, ex. "1.3", "1.5", if fork is set to true -->
<maven.compiler.compilerVersion>1.6</maven.compiler.compilerVersion>
</properties>
</profile>
12:依赖冲突的解决
1).短路优先原则
A->B->logback-1.0.jar
A->logback-1.1.jar
2).先声明先优先原则(先解析先引用)
与项目A pom中配置 引用坐标的顺序有关,如果依赖B在C前的话 就优先B,反之...
A->B->logback-1.0.jar
A->C->logback-1.1.jar
13:<modules>标签详解
此标签在父工程的pom.xml中表示子模块的位置,标签内元素为<module>。以当前父工程所在的文件夹为基准,<module>中填写子模块的相对路径。在Maven build app-parent的时候,它会根据子模块的相互依赖关系整理一个build顺序,然后依次build。所有带有子模块的项目的packaging都为pom
14;dependencyManagement和dependencies区别
dependencies即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)
dependencyManagement里只是声明依赖,并不实现引入,因此子项目需要显示的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。
15:package后启动
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.2</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>run</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>3.1.0</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
16:tomcat7 启动
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<path>/taobao</path>
<port>9090</port>
<uriEncoding>UTF-8</uriEncoding>
</configuration>
</plugin>17:mvn jetty:run
<plugin>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-maven-plugin</artifactId>
<version>9.2.2.v20140723</version>
</plugin>
18:三种启动方式
java -jar 启动方式如下
java -jar test.jar即可以运行这个jar。
java -jar test.war即可以运行这个war。
maven插件启动方式如下
mvn spring-boot:run
idea 启动方式