Idea操作Maven具体应用:

Maven简介

什么是 Maven

Maven 的正确发音是[mevn] "卖v",而不是“马瘟”以及其余什么瘟。
Maven 是一个项目管理工具,它蕴含了一个我的项目对象模型 (POM:Project Object Model),一组规范汇合。

Maven 能解决什么问题

现在咱们构建一个我的项目须要用到很多第三方的类库 Jar包
如写一个应用Spring的Web我的项目就须要引入大量的jar包,
而往往一个Jar包往往又会援用其余Jar包,短少其中任何一个Jar包都会导致我的项目编译失败。
每开发一个我的项目都会须要大量的Jar包 , 一个一般的Java我的项目兴许理论源码只有几MB甚至KB,但加上Jar之后兴许就几十MB。
而同样的我的项目,如果咱们应用 Maven 工程来构建,那么总体上工程的大小会小很多。部署至服务器中...


**Maven就是一款帮忙程序员构建我的项目的工具,咱们只须要通知Maven须要哪些Jar 包,
它会帮忙咱们 下载/提供 所有的Jar,极大晋升开发效率。**

Maven 的两个经典作用:

依赖治理 ~也就是治理jar包(波及仓库常识,上面会讲)~

Maven 的一个外围个性就是依赖治理。
当咱们波及到多模块的我的项目(蕴含成百个模块或者子项目),治理依赖就变成一项艰难的工作。Maven 展现出了它对解决这种情景的高度管制。
传统的 WEB 我的项目中,咱们必须将工程所依赖的 jar 包复制到工程中,导致了工程的变得很大。
那么maven 工程是如何使得工程变得很少呢?
Idea常见一般Maven我的项目目录:

maven工程中不间接将 jar包导入到工程中,而是通过在 pom.xml 文件中增加所需jar包的坐标
这样就很好的防止了 jar 间接引入进来, 使工程变大~
在须要用到 jar 包的时候,再通过pom.xml文件中的坐标
到一个专门用于”寄存 jar 包的仓库”(maven 仓库)中依据坐标从而找到这些 jar 包拿去运行。
而且过程并不需要放心 到仓库中找到 jar 包这样会影响程序性能:
maven 中也有索引的概念,通过建设索引,能够大大提高加载 jar 包的速度,
使得咱们认为 jar 包根本跟放在本地的工程文件中再读取进去的速度是一样的。
”寄存 jar 包的仓库”长什么样?
仓库,顾名思义,也就是寄存一些我的项目必备的食粮(jar包)的中央。Maven中仓库分为三类:

本地仓库:
寄存在本地服务器中,当运行我的项目的时候,maven会主动依据配置文件查找本地仓库,再从本地仓库中调用jar包应用。
近程仓库(私服):
当本地仓库中没有我的项目所须要的jar包时,那么maven会持续查找近程仓库,个别近程仓库指的是公司搭建的公有服务器,也叫私服;
当jar包在私服中查找到之后,maven会将jar包下载到本地仓库中,下次应用的时候就不必再去找近程仓库。
地方仓库:
当近程仓库获取不到jar包时,就须要到地方仓库去查找,并下载在近程仓库中,本地仓库再从近程仓库中下载回来应用。
**此由maven团队保护,据说截止至16年,曾经有2亿个包在仓库中!
能够这么说,咱们须要的包所有起源都是地方仓库,并不需要放心没有jar包。**

一键构建

我的项目从编译、测试、运行、打包、装置、 部署整个过程都交给 maven进行治理,这个过程称为构建。
一键构建: 指的是整个构建过程, 应用 maven几个命令能够轻松实现整个工作。
Maven 规范化构建流程如下:

这个目前晓得就好, 上面联合我的项目实例具体解说~感触;


IDEA应用Maven工程:

我的idea是中文的, 而且版本1.3的有差别的同学多多了解~
留神!应用Maven工程最好要在有网的状况下, 对于一些组件 Jar都是要联网下载的...

首先idea配置maven的装置目录和本地仓库

Idea每次创立一个新的Maven时候, 倡议看看, 不然本地资源库错了Jar乱放到处下载...并不好~
文件——设值——输入框输出Maven

启动工程!!

创立Maven我的项目: ~文件—新建——我的项目~

Next (这里我先建一个一般的我的项目~理解Maven生命周期)

学习web的同学加载工程可能,会须要很长时间下载...缓缓期待即可~ 晓得呈现Src **网卡这种事件很无奈**  Finish

这是我创立好的工程, 是不是感觉毛病什么。


Idea的工具并不是很欠缺对于一些文件,创立并不残缺能够本人补全:根本就是上图的构造
手动在 test文件下创立一个 resources文件:并通过工具标识为资源文件
但要留神: target 文件可不是手动创立的!!!Maven我的项目生命周期主动生成的...次要用于寄存:编译后的文件。

通过上述一系列操作,其实就曾经创立出了一个惯例的 Maven我的项目工程:

| |----main 我的项目的次要代码的中央...
| | |----java ————--寄存我的项目的源文件
| | |----resources ——寄存我的项目资源文件,如spring, hibernate配置文件
| |----test 用于测试项目代码的, 目录相当于 Junit的测试代码的目录
| | |----java ————--寄存所有测试.java文件,如JUnit测试类
| | |----resources ——寄存我的项目测试资源文件,如spring, hibernate配置文件


在Main——Java目录:下创立一个包com.wsm包下 Text.Jave 倡议肯定要加包!!

public class Text {    public void show(){         System.out.println("Hello World");    }}// 这是一个,非常简单广泛的一段Jave代码~ 没人看不懂吧

在Test——Java目录:下创立一个包com.wsm包下 TTest.Jave
次要用于测试, 下面的源码是否能够失常运行... 别想是不是有什么非凡性能就是这个!

import org.junit.Test;public class TTest {        //类名必须,Test结尾(我真是无语了不晓得这个调了良久..)    @Test                   //Junit注解:该办法进行单元测试,(须要Junit包~Pom.xml引入Jar坐标)   public void testShwo(){  //办法名倡议 test结尾,标准..        //申明源码中的类,并调用show(); 测试后果~        Text t = new Text();        t.show();    }}

pom.xml
这是只是根底的标签属性, 因为是根底而且太多了... 我就偷懒了..

<?xml version="1.0" encoding="UTF-8"?><project xmlns="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.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <!-- 指定以后pom模型的版本,maven2 和3都是4 -->    <!-- Pom文件能够用于解耦,最大水平辨别我的项目与我的项目之间的区别 -->    <modelVersion>4.0.0</modelVersion>    <groupId>org.example</groupId>                  <!-- 定义我的项目是哪个公司哪个部门组 -->    <artifactId>MavenWSM</artifactId>               <!-- 组内的惟一id(例如我的项目中的哪个组件:模块名,Maven能够实现模块开发~) -->    <version>1.0-SNAPSHOT</version>                 <!-- 我的项目以后版本,SNAPSHOT为不稳固版本(疾速开发) -->    <!-- groupId  artifactId  version:也决定了我的项目在打包/公布文件的款式/地址:本地仓库下/org/example/MavenWSM/1.0-SNAPSHOT/MavenWSM-1.0-SNAPSHOT.jar  -->    <name>WSM</name>                                <!-- 我的项目别名 -->    <packaging>jar</packaging>                      <!-- 我的项目打包产生的构件类型,例如jar、war、ear、pom... 罕用Jar(默认) war -->    <!--Jar: 个别公司本人制作不便,开发调用的组件Jar...     war: 我的项目打包成war 能够部署至服务器中运行...的格局;  这里不是web工程所以不须要war jar即可~ -->    <!-- 为pom定义一些常量,在pom中的其它中央能够间接援用 应用形式 如下 :${project.build.sourceEncoding} -->    <properties>        <!-- 对立我的项目字符集编码: 底层援用了${project.build.sourceEncoding} 对立字符集  -->        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>        <!-- 设值jdk编码,该办法是指定我的项目的JDK版本 或 在Maven settings.xml中配置对立环境JDK  -->        <maven.compiler.source>1.8</maven.compiler.source>        <maven.compiler.target>1.8</maven.compiler.target>    </properties>    <!-- 中寄存着所有依赖包的形容,也就是提供下载的坐标 -->    <dependencies>        <!-- 每一个dependency 形容一个Jar坐标: 去本地找————找不到去私服下载————在没有去地方仓库下载到私服到本地.. -->        <dependency>            <groupId>junit</groupId>            <!-- 公司组 -->            <artifactId>junit</artifactId>      <!-- 我的项目/jar/模块名 -->            <version>4.9</version>              <!-- 版本 -->            <scope>test</scope>                 <!-- Jar包应用的范畴: 默认应用范畴是compile,则测试代码和主代码都能够应用该代码; -->       <!-- <scope>system</scope>               <systemPath>引入Jar资源门路...</systemPath> -->        </dependency>        <!-- 省略其它更多Jar包的坐标.... -->    </dependencies>        <!-- build Maven的插件    该元素设置了我的项目源码目录,当构建我的项目的时候,构建零碎会编译目录里的源码。-->    <build>    <plugins>        <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-compiler-plugin</artifactId>            <version>3.6.1</version>            <configuration>                <!-- 和下面性能一样都是设值JDK的版本的~ 轻易设值一个即可; -->                <source>1.8</source>                <target>1.8</target>            </configuration>        </plugin>    </plugins>    </build></project>

Pom.xml 详解:这里我会不定时的扩大,更新的哟~

  1. dependencies——>dependency——>==scope依赖范畴==

    A 依赖 B,须要在 A 的 pom.xml 文件中增加 B 的坐标,增加坐标时须要指定依赖范畴,依赖范畴包含↓↓↓
    compile:编译范畴, 默认范畴值,依赖会用在编译、测试、运行, 因为运行时须要所以编译范畴的依赖会被打包。
    provided:编译范畴, provided 依赖在编译和测试时须要,在运行时不须要,比方:servlet api 运行时被 tomcat 容器提供。(抵触反而会报错!)
    runtime:编译范畴,依赖在运行和测试零碎的时候须要,但在编译的时候不须要。 比方:jdbc驱动包。
    test:编译范畴,在编译和运行时都不须要,它们只有在测试编译和测试运行阶段可用。比方:junit。
    system:编译范畴, system 范畴依赖与 provided 相似, 应用本地之外的门路的Jar 须要指定 systemPath 磁盘门路(不举荐!)
  2. 坐标的起源形式:
    从互联网搜寻: 1. http://search.maven.org/ 2.http://mvnrepository.com/
    通过这种形式在也不必到处找Jar了间接来Maven中找到坐标下载到本地就能够用了!
    从其它同学的本地库cope 也是一种方法, 间接将整个仓库copy过去, 更改一下Setting 配置文件即可!~

运行测试:应用Maven进行一键构建

   **咱们能够间接在cmd中通过一系列的maven命令:**   来对咱们的**MavenWSM工程进行:** 清理 编译、测试、运行、打包、装置、部署。

找到我的项目工程的本地门路:
能够在idea 工具中cope门路——Windows+r :复制回车疾速关上文件;
在文件门路中输出 "cmd" 进行文件门路, 不便操作Maven命令; (或者也能够本人手动的 cd: 查找切换门路..)

Maven 常用命令
cmd 进入命令状态,执行 mvn compile,如下图提醒胜利:
compile 是 maven 工程的编译命令,作用是将 src/main/java 下的文件编译为 class 文件输入到 target目录下。
这时你的我的项目中就会呈现 target文件夹:编译好的代码...
BUILD SUCCESS 编译胜利!
cmd 执行 mvn clean 会删除 target 目录及内容, 清理。
cmd 执行 mvn test 执行src/test/java下单元测试类
cmd 执行 mvn package 对于 java 工程执行 package 打成 jar 包,对于 web 工程打成 war包。 并且会蕴含 test操作;
cmd 执行 mvn install 执行 install 将 maven 打成 jar 包或 war 包公布到本地仓库。 蕴含 package 和 test 操作;
cmd 执行 mvn deploy 执行 deploy 将 maven 打成 jar 包或 war 包公布到本地仓库和私服中。 蕴含 package test install 操作;
cmd 执行 mvn clean test 先清理在test测试...
Idea工具能够间接通过双击:对应的生命周期即可:

最终我的项目构造:

编写Maven我的项目, 倡议每一个main下源码是必须要有包的!因为我的项目 打包package 公布install...是将main下的源文件打包~
如果其中有一个独自的文件, 没有一个指定的包, 则默认放在META-INF目录下 学过JSP同学都晓得该目录下文件是只读的不可调的..
这就是Maven的一键构建。是不是超级有意思!!

Maven操作Web工程:

请依照下面案例创立web工程:
如果创立过程太慢能够借鉴:创立时候加:archetypeCatalog | internal会快很多,要留神肯定要抉择对Maven模型

之后的大抵构造是这样的:

并不残缺, 还须要手动增加 src/main/jave文件夹(并且要批改对应文件夹的类型,Jave源文件类型 resource资源文件类型...
最终Web构造:

index.jsp
Idea工具的默认JSP,也并不符合规范, 这个就本人改改吧~

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head>    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">    <title>第一个maven工程</title></head><body>Hello World!</body></html>

之后就能够, 配置Idea的Tomcat 通过Maven构建我的项目Package war包部署至我的项目中~即可;

ok,就酱! 不须要批改任何代码~Idea启动服务则主动加载程序.
你在以后服务器中部署那些我的项目, 就能够执行那些我的项目, 即便你本地原先存在的我的项目但你没有部署 Idea配置的服务器也是拜访不了的~

Maven我的项目应用自定义的jar

ok 到这儿web工程也就写完了.
至于自己在 main——java——com.wsm.Test——cs 是自己的测试Demo
失常状况这里写的是:dao entity service comtroller....程序代码(SSM SSH),可别被自己凌乱了~


本次测试: 一个Maven我的项目引入另一个Maven我的项目程序:实现模块开发

pom.xml

    <!-- 还记得这个吗? 一个一般的资源援用, 但!        仔细观察,这就是方才写的 组 模块名 版本...         Maven install将我的项目打包Jar至本地,其它Maven项即可间接 dependency 引入应用,该项目标类/办法~        是不是感觉越来越高级了....当初曾经能够本人开发Jar 不便日后开发应用了呢~    -->      </dependencies>    <dependency>      <groupId>org.example</groupId>      <artifactId>MavenWSM</artifactId>      <version>1.0-SNAPSHOT</version>    </dependency>  </dependencies>

cs.java

import com.wsm.Text;   //这里的com.wsm.Text是引入我的项目的包,如果没有包的话文件存在MATE——INF是无奈引入的!(所以倡议源码都放在包下~一种标准吧!)public class CS {    public static void main(String[] args) {        //创立自定义Jar包中的类对象,调用办法();        Text text = new Text();        text.show();    }}

间接右击, run ! “Hello World”


Maven装置:

请单击.

最初的最初, 终于写完了, 求个赞呀!