Maven学习个人笔记

                     Maven

1.解压部署Maven核心程序

         ①检查JAVA_HOME环境变量

                   C:\Windows\System32>echo%JAVA_HOME%

                   D:\DevInstall\jdk1.7.0_07

         ②解压Maven的核心程序

                   将apache-maven-3.2.2-bin.zip解压到一个非中文无空格的目录下。例如:D:\DevInstall\apache-maven-3.2.2

         ③配置环境变量

                   M2_HOMED:\DevInstall\apache-maven-3.2.2

                   path D:\DevInstall\apache-maven-3.2.2\bin

         ④查看Maven版本信息验证安装是否正确

                   C:\Windows\System32>mvn-v

                   ApacheMaven 3.2.2 (45f7c06d68e745d05611f7fd14efb6594181933e;2014-06-17T21:51:42+08:00)

                   Mavenhome: D:\DevInstall\apache-maven-3.2.2\bin\..

                   Javaversion: 1.7.0_07, vendor: Oracle Corporation

                   Javahome: D:\DevInstall\jdk1.7.0_07\jre

                   Defaultlocale: zh_CN, platform encoding: GBK

                   OSname: "windows 7", version: "6.1", arch: "amd64",family: "windows"

2.修改本地仓库

         ①默认本地仓库位置:~\.m2\repository

                   ~表示当前用户的家目录,例如:C:\Users\[你当前登录系统的用户名]

         ②指定本地仓库位置的配置信息文件:apache-maven-3.2.2\conf\settings.xml

         ③在根标签settings下添加如下内容:<localRepository>[本地仓库路径,也就是RepMaven.zip的解压目录]</localRepository>

Maven是什么?

一款服务于JAVA平台的自动化构建工具

演化过程:Make>>>>>ant>>>>Maven>>>GRadle

读  麦文 妹文 不要读成马文

1)      构建

概念:以  JAVA源文件、框架配置文件、jsp、HTML、图片等资源为原材料 去生产一个可以运行的项目过程。

   编译

   部署

   搭建

2Web工程编译后就是在WEBCONTENT下面的把其改为项目名称

在开发过程中,所有的路径或配置文件的路径都是以编译结果的目录路径为标准。

3)构建过程的几个主要环节

①清理:删除以前的编译结果,为重新编译做好准备。

 ②编译:将 Java 源程序编译为字节码文件。

 ③测试:针对项目中的关键点进行测试,确保项目在迭代开发过程中关键点的正确性。

④报告:在每一次测试后以标准的格式记录和展示测试结果。

⑤打包:将一个包含诸多文件的工程封装为一个压缩文件用于安装或部署。Java 工程对应 jar 包,Web 工程对应 war 包。

⑥安装:在 Maven 环境下特指将打包的结果——jar 包或 war 包安装到本地仓库中。

⑦部署:将打包的结果部署到远程仓库或将 war 包部署到服务器上运行。

4)自动化构建

Maven 核心概念

 Maven 能够实现自动化构建是和它的内部原理分不开的,这里我们从 Maven 的九个核心概念入手,看看 Maven 是如何实现自动化构建的

 ①POM

 约定的目录结构

坐标

依赖管理

⑤仓库管理

⑥生命周期

⑦插件和目标

⑧继承

⑨聚合

创建一个MAVEN工程

一)创建约定的目录结构

约定的目录结构 约定的目录结构对于Maven 实现自动化构建而言是必不可少的一环,就拿自动编译来说,Maven 必须能找到 Java 源文件,下一步才能编译,而编译之后也必须有一个准确的位置保持编译得到的字节码文件。我们在开发中如果需要让第三方工具或框架知道我们自己创建的资源在哪,那么基本上就是两种方式:

①通过配置的形式明确告诉它

②基于第三方工具或框架的约定。

 现 JavaEE 开发领域普遍认同一个观点:约定>配置>编码。意思就是能用配置解决的问题就不编码, 能基于约定的就不进行配置。而 Maven 正是因为指定了特定文件保存的目录才能够对我们的 Java 工程进行自动化构建。

第一个Maven工程

①目录结构

                Hello

                |---src

                |---|---main

                |---|---|---java

                |---|---|---resources

                |---|---test

                |---|---|---java

                |---|---|---resources

                |---pom.xml

1)   创建约定的目录结构

【1】      根目录:工程名 Hello

【2】      Src目录:源码

【3】      Pom.xml文件:Maven工程的核心配置文件

【4】      Main目录:存放主程序

【5】      Test目录:存放测试程序

【6】      Java目录:存放JAVA源文件

【7】      Resources目录:存放框架或其他工具的配置文件

②POM文件内容

<?xmlversion="1.0" ?>

<projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">

         <modelVersion>4.0.0</modelVersion>

         <groupId>com.atguigu.maven</groupId>

         <artifactId>Hello</artifactId>

         <version>0.0.1-SNAPSHOT</version>

         <name>Hello</name>

          

         <dependencies>

                   <dependency>

                            <groupId>junit</groupId>

                            <artifactId>junit</artifactId>

                            <version>4.0</version>

                            <scope>test</scope>

                   </dependency>

         </dependencies>

</project>

         ③编写主程序代码

                   在src/main/java/com/atguigu/maven目录下新建文件Hello.java,内容如下

                   package com.atguigu.maven;

                   public class Hello {

                            public StringsayHello(String name){

                                     return"Hello "+name+"!";

                            }

                   }

         ④编写测试代码

                   在/src/test/java/com/atguigu/maven目录下新建测试文件HelloTest.java

                   package com.atguigu.maven;         

                   import org.junit.Test;

                   import staticjunit.framework.Assert.*;

                   public class HelloTest {

                            @Test

                            public voidtestHello(){

                                     Hello hello= new Hello();

                                     Stringresults = hello.sayHello("litingwei");

                                     assertEquals("Hellolitingwei!",results);        

                            }

                   }

         ⑤运行几个基本的Maven命令

                   mvn compile    编译

                   mvn clean         清理

                   mvn test  测试

                   mvn package   打包

                   ※注意:运行Maven命令时一定要进入pom.xml文件所在的目录!

常用的Maven命令

  注意:执行与构建过程相关的Maven命令,必须进入pom.xml所在目录

      与构建过程相关的:编译、测试、打包、、、、、、、

   常用命令:

1、  mvn clean:清理

2、  mvn compile:编译测试程序

3、  mvn test-compile : 编译测试程序

4、  mvn test :执行测试

5、  mvn package:打包

6、  mvn install 安装

7、  mvn site:生产站点

     关于联网下载核心程序:

Maven 的核心程序中仅仅定义了抽象的生命周期,而具体的操作则是由 Maven 的插件来完成的。可是 Maven 的插件并不包含在 Maven 的核心程序中,在首次使用时需要联网下载。下载得到的插件会被保存到本地仓库中。本地仓库默认的位置是:~\.m2\repository。

本地仓库的默认位置:系统当前登录用家文件下面C:\Users\dukun\.m2\repository

修改默认本地仓库的位置,可以让Maven到指定目录下找插件。

配置文件在E:\apache-maven-3.2.2\conf下面的settings.xml里面

<localRepository>/path/to/local/repo</localRepository>这个标签

将内容修改为已经准备好的路径

二)POM

POM: Project Object Model:项目对象模型。将 Java 工程的相关信息封装为对象作为便于操作和管理的模型。 Maven 工程的核心配置。可以说学习 Maven 就是学习 pom.xml 文件中的配置。

三)坐标 gav

     6.1 几何中的坐标

 [1]在一个平面中使用 x、y 两个向量可以唯一的确定平面中的一个点。

 [2]在空间中使用 x、y、z 三个向量可以唯一的确定空间中的一个点。

 6.2 Maven 的坐标 使用如下三个向量在 Maven 的仓库中唯一的确定一个Maven 工程。[1]groupid:公司或组织的域名倒序+当前项目名称

<groupid>com.nari.maven < /groupid >

 [2]artifactId:当前项目的模块名称

 < artifactId >Hello</ artifactId>

[3]version:当前模块的版本

   < version>0.0.1-SNAPSHOT</version>

6.3 如何通过坐标到仓库中查找 jar 包?

[1]将 gav 三个向量连起来 com.nari.maven+Hello+0.0.1-SNAPSHOT

 [2]以连起来的字符串作为目录结构到仓库中查找

com/ nari /maven/Hello/0.0.1-SNAPSHOT/Hello-0.0.1-SNAPSHOT.jar

 注意:我们自己的 Maven 工程必须执行安装操作才会进入仓库。安装的命令是:mvn install

)仓库

1)分类

[1]本地仓库:为当前本机电脑上的所有 Maven 工程服务。

 [2]远程仓库

 (1)私服:架设在当前局域网环境下,为当前局域网范围内的所有 Maven 工程服务。

 (2)中央仓库:架设在Internet 上,为全世界所有 Maven 工程服务。

(3)中央仓库的镜像:架设在各个大洲,为中央仓库分担流量。减轻中央仓库的压力,同时更快的响应用户请求。

2)仓库中的文件

[1]Maven 的插件

[2]我们自己开发的项目的模块

[3]第三方框架或工具的 jar 包

※不管是什么样的 jar 包,在仓库中都是按照坐标生成目录结构,所以可以通过统一的方式查询或依赖。

五)依赖

 1Maven 解析依赖信息时会到本地仓库中查找被依赖的JAR包。

     对于我们自己的开发的Maven工程,使用mvn install命令安装后就可以进入仓库。

Maven 中最关键的部分,我们使用 Maven 最主要的就是使用它的依赖管理功能。要理解和掌握 Maven 的依赖管理,我们只需要解决一下几个问题:

①依赖的目的是什么当 A jar 包用到了 B jar 包中的某些类时,A 就对 B 产生了依赖,这是概念上的描述。那么如何在项目中以依赖的方式引入一个我们需要的 jar 包呢?答案非常简单,就是使用 dependency 标签指定被依赖 jar 包的坐标就可以了。

<dependency>

                            <groupId>com.maven</groupId>

                            <artifactId>Hello</artifactId>

                            <version>0.0.1-SNAPSHOT</version>

                            <scope>compile</scope>

</dependency>

 2 依赖的范围

       

      SCOPE 标签就是依赖的范围

【1】      compile

对主程序是否有效    有效

对测试程序是否有效  有效

是否参加打包        参与打包的

【2】      test范围依赖

对主程序是否有效    无效(在主程序里看不到)

对测试程序是否有效  有效

是否参加打包        不参与打包

典型例子        junit

【3】      Provided 范围依赖

对主程序是否有效    有效

对测试程序是否有效  有效

是否参加打包        不参与打包的

是否参加部署        不参加部署

典型例子:servlet-api.jar

 

 

六)生命周期

 1)各个构建环节执行的顺序:不能打乱顺序,必须按照既定的正确顺序来执行。

 2)Maven 的核心程中定义了抽象的生命周期,生命周期中各个阶段的具体任务由插件来完成的。

3)Maven核心程序为了更好的实现自动化构建,按照这一的特征执行生命周期中的各个阶段,不论现在要执行生命周期中的哪一个阶段,都是从这个生命周期最初的位置开始执行。

1 什么是 Maven 的生命周期?

●Maven 生命周期定义了各个构建环节的执行顺序,有了这个清单,Maven 就可以自动化的执行构建命令了。

 ●Maven 有三套相互独立的生命周期,分别是:

 ①Clean Lifecycle 在进行真正的构建之前进行一些清理工作。

 ②Default Lifecycle 构建的核心部分,编译,测试,打包,安装,部署等等。

 ③Site Lifecycle 生成项目报告,站点,发布站点。

它们是相互独立的,你可以仅仅调用 clean 来清理工作目录,仅仅调用 site 来生成站点。当然你也可以直接运行 mvn clean install site 运行所有这三套生命周期。 每套生命周期都由一组阶段(Phase)组成,我们平时在命令行输入的命令总会对应于一个特定的阶段。比如,运行 mvn clean,这个 clean 是 Clean 生命周期的一个阶段。有 Clean 生命周期,也有 clean 阶段。

 9.2 Clean 生命周期 Clean 生命周期一共包含了三个阶段:

①pre-clean 执行一些需要在 clean 之前完成的工作

②clean 移除所有上一次构建生成的文件

③post-clean 执行一些需要在 clean 之后立刻完成的工作

9.3 Site 生命周期

①pre-site 执行一些需要在生成站点文档之前完成的工作

②site 生成项目的站点文档

③post-site 执行一些需要在生成站点文档之后完成的工作,并且为部署做准备 ④site-deploy 将生成的站点文档部署到特定的服务器上这里经常用到的是 site 阶段和 site-deploy 阶段,用以生成和发布 Maven 站点,这可是 Maven 相当强大的功能,Manager 比较喜欢,文档及统计数据自动生 ,很好看。

9.4 Default 生命周期 Default 生命周期是 Maven 生命周期中最重要的一个,绝大部分工作都发生在这个生命周期中。这里,只解释一些比较重要和常用的阶段: validate generate-sources generate-resources process-resources 复制并处理资源文件,至目标目录,准备打包。 compile 编译项目的源代码。 process-classes generate-test-sources process-test-sourcesgenerate-test-resources process-test-resources 复制并处理资源文件,至目标测试目录。test-compile 编译测试源代码。 process-test-classes test 使用合适的单元测试框架运行测试。这些测试代码不会被打包或部署。 prepare-package package 接受编译好的代码,打包成可发布的格式,如JAR。 pre-integration-test integration-test post-integration-test verifyinstall 将包安装至本地仓库,以让其它项目依赖。 deploy 将最终的包复制到远程的仓库,以让其它开发人员与项目共享或部署到服务器上运行。

 9.5 生命周期与自动化构建 运行任何一个阶段的时候,它前面的所有阶段都会被运行,例如我们运行 mvn install 的时候,代码会被编译,测试,打包。这就是 Maven 为什么能够自动执行构建过程的各个环节的原因。此外,Maven 的插件机制是完全依赖 Maven 的生命周期的,因此理解生命周期至关重要。

 10 插件和目标

●Maven 的核心仅仅定义了抽象的生命周期,具体的任务都是交由插件完成的。

 ●每个插件都能实现多个功能,每个功能就是一个插件目标。

●Maven 的生命周期与插件目标相互绑定,以完成某个具体的构建任务。

 例如:compile 就是插件 maven-compiler-plugin 的一个目标;pre-clean 是插件maven-clean-plugin 的一个目标。

 

七)eciplse设置

 

   Maven 插件的设置

1)  installations:指定Maven的核心程序的位置。不建议使用插件自带的Maven程序,而应该使用我们自己解压的那个

2)  user setting:指定conf/settings.xml的位置,进而获取本地仓库的位置

 

         基本操作:

1)  创建Maven版的JAVA工程

2)  创建Maven版的web工程

3)  执行Maven命令

创建JAVA工程

下面是创建JAVA工程:打包成JAR包 web项目为WAR包

 

 

 

默认使用是JDK1.5这个需要手动修改

 

 

还需要改下面

 

 

第二种方法:修改MAVEN的配置文件

   ①设置通过Maven创建的工程的JDK版本——一劳永逸

      [1]打开settings.xml文件

      [2]找到profiles标签

      [3]加入如下配置

          <profile>

              <id>jdk-1.8</id>

              <activation>

                  <activeByDefault>true</activeByDefault>

                  <jdk>1.8</jdk>

              </activation>

              <properties>

                  <maven.compiler.source>1.8</maven.compiler.source>

                  <maven.compiler.target>1.8</maven.compiler.target>

                           <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>

          </properties>

          </profile>

 

生成WEB项目

点finish

此时还不是一个web项目需要去配置

 

创建一个JSP页面此时会报错 这里需要引用servlet-api

 

在pom.xml里面加入servlet-api的依赖

 

 <dependencies>

    <!-- ServletAPI依赖 -->

        <dependency>

            <groupId>javax.servlet</groupId>

            <artifactId>servlet-api</artifactId>

            <version>2.5</version>

<!--provided不会去打这个依赖的WAR包 test也不会 只有compile才会打包-->

            <scope>provided</scope>

        </dependency>

  </dependencies>

 

 

在JSP写EL表达式 会报如下错误 需要引入JSP-API

 

     <!--JSPAPI依赖 -->

        <dependency>

            <groupId>javax.servlet.jsp</groupId>

            <artifactId>jsp-api</artifactId>

            <version>2.1.3-b06</version>

            <scope>provided</scope>

  </dependency>

 

这个scope必须是provided  不然会发生JAR冲突

依赖的高级

1)  依赖的传递性

【1】      好处:可以传递的依赖不必再每个模块工程中都重复声明,在“最下面”的工程中依赖一次即可。

在项目里面要有一个专门的工程来存放需要的依赖。

注意:非compile范围的不能传递,需要在pom.xml需要加入依赖

2)  依赖的排除。

排除的方式:

<dependency>

        <groupId>com.atguigu.maven</groupId>

        <artifactId>HelloFriend</artifactId>

        <version>0.0.1-SNAPSHOT</version>

        <type>jar</type>

        <scope>compile</scope>

        <!-- 依赖的排除,排除不需要的包不关心版本 -->

            <exclusions>

               <exclusion>

                  <groupId></groupId>

                  <artifactId></artifactId>

               </exclusion>

            </exclusions>

   </dependency>

依赖的原则

  1:作用:接近模块工程之间的JAR包冲突

  2:情景1:验证路径最短者优先原则

   情景2:路径相同时声明优先原则

统一管理依赖的版本:

 1情景举例

这里对SPRING各个JAR包的依赖版本都是4.0.0

如果需要统一升级为4.1.1这么办?手动一一一修改不可靠

建议配置方式:

i使用properties标签内使用自定义标签统一声明版本号

    <properties>

       <atguigu.spring.version>4.0.0.RELEASE</atguigu.spring.version>

       <project.build.sourceEnocoding>UTF-8</project.build.sourceEnocoding>

    </properties>

ii.在需要统一版本的位置使用${自定义标签名称}引用声明的版本号

   <version>${atguigu.spring.version}</version>

 

    <dependency>

           <groupId>org.springframework</groupId>

           <artifactId>spring-web</artifactId>

           <version>${atguigu.spring.version}</version>

        </dependency>

   

  3、其实properties标签配合自定义标签声明数据的配置并不止用于声明依赖的版本号。

凡是需要统一声明后再引用的场合都可以使用。

<properties>

       <atguigu.spring.version>4.0.0.RELEASE</atguigu.spring.version>

       <project.build.sourceEnocoding>UTF-8</project.build.sourceEnocoding>

    </properties>

七、继承

   1、现状

      由于test范围的依赖不能传递,所以必然会分散到各个模块工程中,很容易造成版本不一致的。

   2:统一管理各个模块工程队JUNIT的依赖的版本。

   3 将junit依赖统一提取到父工程中,在子工程中声明junit依赖是不指定的版本,以父工程统一设定的为准。

  4创建一个Maven工程作为父工程。打包的方式POM。

<modelVersion>4.0.0</modelVersion>

 <groupId>com.atguigu.maven</groupId>

 <artifactId>ParentTest</artifactId>

 <version>0.0.1-SNAPSHOT</version>

  <packaging>pom</packaging>

 

 子工程中声明对父工程的引用。

<!-- 在子工程中声明对父工程是引用 -->

     <parent>

        <groupId>com.atguigu.maven</groupId>

        <artifactId>ParentTest</artifactId>

        <version>0.0.1-SNAPSHOT</version>

        <!-- 以当前文件文基准的父工程pomxml文件的相对路径 -->

         <relativePath>。。/ParentTest/pom.xml</relativePath>

     </parent>

将子工程中的坐标与父工程的坐标的重复的内容删除

 在父工程中统一管理junit依赖

<!-- 配置子工程的依赖的管理 -->

 <dependencyManagement>

    <dependencies>

       <dependency>

          <groupId>junit</groupId>

            <artifactId>junit</artifactId>

            <version>4.9</version>

            <scope>test</scope>

       </dependency>

    

    </dependencies>

  </dependencyManagement>

 

在子工程中删除junit依赖的版本号部分

 

8聚合

作用:一键安装各个模块的工程。

配置方式:在一个总的聚合工程中配置各个参与聚合的模块。

<!-- 聚合各个模块 -->

 <modules>

   <module>../Hello</module>

 <module>../HelloFriend</module>

 <module>../MakeFrinds</module>

  </modules>


猜你喜欢

转载自blog.csdn.net/qq_36697880/article/details/80875506