1. 为什么要使用 Maven?它能帮助我们解决什么问题?
    ①添加第三方 jar 包
    在今天的 JavaEE 开发领域,有大量的第三方框架和工具可以供我们使用。要使用这些 jar 包最简单的方法就是复制粘贴到 WEB-INF/lib 目录下。但是这会导致每次创建一个新的工程就需要将 jar 包重复复 到 lib 目录下,从而造成工作区中存在大量重复的文件,让我们的工程显得很臃肿。而使用 Maven 后每个 jar 包本身只在本地仓库中保存一份,需要 jar 包的工程只需要以坐标的方式
    ②jar 包之间的依赖关系
    jar 包往往不是孤立存在的,很多 jar 包都需要在其他 jar 包的支持下才能够正常工作,我们称之为 ar 包之间的依赖关系。最典型的例子是:commons-fileupload-1.3.jar 依赖于 commons-io-2.0.1.jar,如果 没有 IO 包,FileUpload 包就不能正常工作。
    下图是 Spring 所需 jar 包的部分依赖关系

③获取第三方 jar 包
JavaEE 开发中需要使用到的 jar 包种类繁多,几乎每个 jar 包在其本身的官网上的获取方式都不尽相同。为了查找一个 jar 包找遍互联网,身心俱疲,没有经历过的人或许体会不到这种折磨。不仅如此,费劲心血找的 jar 包里有的时候并没有你需要的那个类,又或者又同名的类没有你要的方法——以不规 范的方式获取的 jar 包也往往是不规范的。
使用 Maven 我们可以享受到一个完全统一规范的 jar 包管理体系。你只需要在你的项目中以坐标的方式依赖一个 jar 包,Maven 就会自动从中央仓库进行下载,并同时下载这个 jar 包所依赖的其他 jar 包

  1. 安装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_HOME D:\DevInstall\apache-maven-3.2.2
    path D:\DevInstall\apache-maven-3.2.2\bin
    ④查看Maven版本信息验证安装是否正确
    C:\Windows\System32>mvn -v
    Apache Maven 3.2.2 (45f7c06d68e745d05611f7fd14efb6594181933e; 2014-06-17T21:51:42+08:00)
    Maven home: D:\DevInstall\apache-maven-3.2.2\bin…
    Java version: 1.7.0_07, vendor: Oracle Corporation
    Java home: D:\DevInstall\jdk1.7.0_07\jre
    Default locale: zh_CN, platform encoding: GBK
    OS name: “windows 7”, version: “6.1”, arch: “amd64”, family: “windows”
    2.修改本地仓库
    ①默认本地仓库位置:~.m2\repository
    ~表示当前用户的家目录,例如:C:\Users[你当前登录系统的用户名]
    ②指定本地仓库位置的配置信息文件:apache-maven-3.2.2\conf\settings.xml
    ③在根标签settings下添加如下内容:
<!-- 本地仓库 -->
  <localRepository>/Users/shenrongrong/maven/mavenJar</localRepository>


<!-- 国内镜像仓库地址 -->
<mirror>
      <id>aliyunmaven</id>
      <mirrorOf>*</mirrorOf>
      <name>阿里云公共仓库</name>
      <url>https://maven.aliyun.com/repository/public</url>
</mirror>

<!-- 创建maven 项目默认的jdk -->
<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>
  1. 第一个Maven工程
    ①目录结构
    Hello
    |—src
    |—|---main
    |—|---|—java
    |—|---|—resources
    |—|---test
    |—|---|—java
    |—|---|—resources
    |—pom.xml
    ②POM文件内容
  2. Maven 核心概念
    ①POM
    ②约定的目录结构
    ③坐标
    ④依赖管理
    ⑤仓库管理
    a)约定的目录结构
    约定的目录结构对于 Maven 实现自动化构建而言是必不可少的一环,就拿自动编译来说,Maven 必须能找到 Java 源文件,下一步才能编译,而编译之后也必须有一个准确的位置保持编译得到的字节码文件。
    我们在开发中如果需要让第三方工具或框架知道我们自己创建的资源在哪,那么基本上就是两种方式:
    ①通过配置的形式明确告诉它
    ②基于第三方工具或框架的约定

    b)POM
    Project Object Model:项目对象模型。将 Java 工程的相关信息封装为对象作为便于操作和管理的模型。
    Maven 工程的核心配置。可以说学习 Maven 就是学习 pom.xml 文件中的配置。
    c)坐标
    1. 几何中的坐标
    [1]在一个平面中使用 x、y 两个向量可以唯一的确定平面中的一个点。
    [2]在空间中使用 x、y、z 三个向量可以唯一的确定空间中的一个点。
    2. Maven 的坐标
    使用如下三个向量在 Maven 的仓库中唯一的确定一个 Maven 工程。
    [1]groupid:公司或组织的域名倒序+当前项目名称
    [2]artifactId:当前项目的模块名称
    [3]version:当前模块的版本
```xml
 <groupId>com.atguigu.maven</groupId> 
 	<artifactId>Hello</artifactId> 
 <version>0.0.1-SNAPSHOT</version>
 ```
  1. 如何通过坐标到仓库中查找 jar 包?
    [1]将 gav 三个向量连起来
    com.atguigu.maven+Hello+0.0.1-SNAPSHOT
    [2]以连起来的字符串作为目录结构到仓库中查找
    com/atguigu/maven/Hello/0.0.1-SNAPSHOT/Hello-0.0.1-SNAPSHOT.jar
    ※注意:我们自己的 Maven 工程必须执行安装操作才会进入仓库。安装的命令是:mvn install
    d)统一管理所依赖 jar 包的版本
    对同一个框架的一组 jar 包最好使用相同的版本。为了方便升级框架,可以将 jar 包的版本信息统一提取出来
    [1]统一声明版本号
<properties> 
	<atguigu.spring.version>4.1.1.RELEASE</atguigu.spring.version> 
</properties>

其中 atguigu.spring.version 部分是自定义标签。
[2]引用前面声明的版本号

<dependencies> 
<dependency> 
<groupId>org.springframework</groupId> 
<artifactId>spring-core</artifactId> 
<version>${atguigu.spring.version}</version>
</dependency> 
…… 
</dependencies>

[3]其他用法

<properties> 
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
</properties>

e)仓库

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

[2]远程仓库

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

java中创建maven项目 java系统项目maven怎么编译_apache

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

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

仓库地址:

java中创建maven项目 java系统项目maven怎么编译_java中创建maven项目_02

Eclipse 配置maven

java中创建maven项目 java系统项目maven怎么编译_maven_03

1)installations – add

2)User settings

  1. 创建maven 项目的步骤:
    1.新建一个maven项目

2.勾选

java中创建maven项目 java系统项目maven怎么编译_java中创建maven项目_04

3.GAV — G-groupId A- artifactId V- version

java中创建maven项目 java系统项目maven怎么编译_jar_05

点击finish之后的目录结构

java中创建maven项目 java系统项目maven怎么编译_jar_06

  1. 右击项目属性 – project facets
  2. java中创建maven项目 java系统项目maven怎么编译_java_07


  3. java中创建maven项目 java系统项目maven怎么编译_apache_08


  4. java中创建maven项目 java系统项目maven怎么编译_maven_09


  5. java中创建maven项目 java系统项目maven怎么编译_jar_10

  6. Mac 电脑 maven 项目 -不能添加 到tomcat

Maven (maven文件中的conf文件下) - setting.xml

<?xml version="1.0" encoding="UTF-8"?>


<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
  
  <!-- 本地仓库 -->
  <localRepository>/Users/shenrongrong/maven/mavenJar</localRepository>

  
  <pluginGroups>
    
  </pluginGroups>

  
  <proxies>
   
  </proxies>

  
  <servers>
    
  </servers>

  <mirrors>
    <!-- 阿里云公共仓库  -  镜像 -->
    <mirror>
      <id>aliyunmaven</id>
      <mirrorOf>*</mirrorOf>
      <name>阿里云公共仓库</name>
      <url>https://maven.aliyun.com/repository/public</url>
    </mirror>
  </mirrors>

  
  <profiles>
    <!-- 创建maven 项目的  默认的jdk 版本 -->
    <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>
  </profiles>

</settings>