/**PageBeginHtml Block Begin **/ /***自定义返回顶部小火箭***/ /*生成博客目录的JS 开始*/ /*生成博客目录的JS 结束*/

maven 创建项目


一:   配置Maven


1:Maven 是什么


Maven (opens new window)是一个项目管理工具。它负责管理项目开发过程中的几乎所有的东西。

版本 - maven 有自己的版本定义和规则。 构建 - maven 支持许多种的应用程序类型,对于每一种支持的应用程序类型都定义好了一组构建规则和工具集。 输出物管理 - maven 可以管理项目构建的产物,并将其加入到用户库中。这个功能可以用于项目组和其他部门之间的交付行为。 依赖关系 - maven 对依赖关系的特性进行细致的分析和划分,避免开发过程中的依赖混乱和相互污染行为 文档和构建结果 - maven 的 site 命令支持各种文档信息的发布,包括构建过程的各种输出,javadoc,产品文档等。 项目关系 - 一个大型的项目通常有几个小项目或者模块组成,用 maven 可以很方便地管理。 移植性管理 - maven 可以针对不同的开发场景,输出不同种类的输出结果。

1.1:Maven 的生命周期


maven 把项目的构建划分为不同的生命周期(lifecycle)。粗略一点的话,它这个过程(phase)包括:编译、测试、打包、集成测试、验证、部署。maven 中所有的执行动作(goal)都需要指明自己在这个过程中的执行位置,然后 maven 执行的时候,就依照过程的发展依次调用这些 goal 进行各种处理。

这个也是 maven 的一个基本调度机制。一般来说,位置稍后的过程都会依赖于之前的过程。当然,maven 同样提供了配置文件,可以依照用户要求,跳过某些阶段。


1.2:Maven 的标准工程结构

Maven 的标准工程结构如下:

|-- pom.xml(maven的核心配置文件)
|-- src
|-- main
  |-- java(java源代码目录)
  |-- resources(资源文件目录)
|-- test
    |-- java(单元测试代码目录)
|-- target(输出目录,所有的输出物都存放在这个目录下)
    |-- classes(编译后的class文件存放处)


1.3:Maven 的"约定优于配置"


所谓的"约定优于配置",在 maven 中并不是完全不可以修改的,他们只是一些配置的默认值而已。但是除非必要,并不需要去修改那些约定内容。maven 默认的文件存放结构如下:

     每一个阶段的任务都知道怎么正确完成自己的工作,比如 compile 任务就知道从 src/main/java 下编译所有的 java 文件,并把它的输出 class 文件存放到 target/classes 中。

     对 maven 来说,采用"约定优于配置"的策略可以减少修改配置的工作量,也可以降低学习成本,更重要的是,给项目引入了统一的规范。

1.4:Maven 的版本规范


maven 使用如下几个要素来唯一定位某一个输出物:

groupId - 团体、组织的标识符。团体标识的约定是,它以创建这个项目的组织名称的逆向域名(reverse domain name)开头。一般对应着 JAVA 的包的结构。例如 org.apache
artifactId - 单独项目的唯一标识符。比如我们的 tomcat, commons 等。不要在 artifactId 中包含点号(.)。
version - 一个项目的特定版本。
packaging - 项目的类型,默认是 jar,描述了项目打包后的输出。类型为 jar 的项目产生一个 JAR 文件,类型为 war 的项目产生一个 web 应用。
      例如:想在 maven 工程中引入 4.12 版本的 junit 包,添加如下依赖即可。

<dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <version>4.12</version>
  <scope>compile</scope>
</dependency>


maven 有自己的版本规范,一般是如下定义 <major version>、<minor version>、<incremental version>-<qualifier> ,比如 1.2.3-beta-01。要说明的是,maven 自己判断版本的算法是 major,minor,incremental 部分用数字比 较,qualifier 部分用字符串比较,所以要小心 alpha-2 和 alpha-15 的比较关系,最好用 alpha-02 的格式。

maven 在版本管理时候可以使用几个特殊的字符串 SNAPSHOT,LATEST,RELEASE。比如"1.0-SNAPSHOT"。各个部分的含义和处理逻辑如下说明:

SNAPSHOT - 这个版本一般用于开发过程中,表示不稳定的版本。
LATEST - 指某个特定构件的最新发布,这个发布可能是一个发布版,也可能是一个 snapshot 版,具体看哪个时间最后。
RELEASE - 指最后一个发布版。





2、Maven 安装--windows


2.1:环境准备

Maven 依赖于 Java,所以本地必须安装 JDK。

打开控制台,执行 java -version 确认本地已安装 JDK。

$ java -version
java version "1.8.0_191"
Java(TM) SE Runtime Environment (build 1.8.0_191-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.191-b12, mixed mode)


2.2:下载解压

进入 官网下载地址 (opens new window)选择合适版本,下载并解压到本地。解压命令如下:

# 以下解压命令分别针对 zip 包和 tar 包
unzip apache-maven-3.6.3-bin.zip
tar xzvf apache-maven-3.6.3-bin.tar.gz

2.3: 环境变量-MAVEN_HOME

添加环境变量 MAVEN_HOME,值为 Maven 的安装路径。

3.3.1:配置 Unix 系统环境变量

输入 vi /etc/profile ,添加环境变量如下:

# MAVEN 的根路径
export MAVEN_HOME=/opt/maven/apache-maven-3.5.2
export PATH=$MAVEN_HOME/bin:$PATH

3.3.2:配置 Windows 系统环境变量

右键 “计算机”,选择 “属性”,之后点击 “高级系统设置”,点击"环境变量",来设置环境变量,有以下系统变量需要配置:

2.4:检测安装成功

检验是否安装成功,执行 mvn -v 命令,如果输出类似下面的 maven 版本信息,说明配置成功。


$ mvn -v
Apache Maven 3.5.4 (1edded0938998edf8bf061f1ceb3cfdeccf443fe)
Maven home: /opt/maven/apache-maven-3.5.4
Java version: 1.8.0_191, vendor: Oracle Corporation, runtime: /mnt/disk1/jdk1.8.0_191/jre
Default locale: zh_CN, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-327.el7.x86_64", arch: "amd64", family: "unix"


2.5 maven 命令

生命周期    阶段描述
mvn validate    验证项目是否正确,以及所有为了完整构建必要的信息是否可用
mvn generate-sources    生成所有需要包含在编译过程中的源代码
mvn process-sources    处理源代码,比如过滤一些值
mvn generate-resources    生成所有需要包含在打包过程中的资源文件
mvn process-resources    复制并处理资源文件至目标目录,准备打包
mvn compile    编译项目的源代码
mvn process-classes    后处理编译生成的文件,例如对 Java 类进行字节码增强(bytecode enhancement)
mvn generate-test-sources    生成所有包含在测试编译过程中的测试源码
mvn process-test-sources    处理测试源码,比如过滤一些值
mvn generate-test-resources    生成测试需要的资源文件
mvn process-test-resources    复制并处理测试资源文件至测试目标目录
mvn test-compile    编译测试源码至测试目标目录
mvn test    使用合适的单元测试框架运行测试。这些测试应该不需要代码被打包或发布
mvn prepare-package    在真正的打包之前,执行一些准备打包必要的操作。这通常会产生一个包的展开的处理过的版本(将会在 Maven 2.1+中实现)
mvn package    将编译好的代码打包成可分发的格式,如 JAR,WAR,或者 EAR
mvn pre-integration-test    执行一些在集成测试运行之前需要的动作。如建立集成测试需要的环境
mvn integration-test    如果有必要的话,处理包并发布至集成测试可以运行的环境
mvn post-integration-test    执行一些在集成测试运行之后需要的动作。如清理集成测试环境。
mvn verify    执行所有检查,验证包是有效的,符合质量规范
mvn install    安装包至本地仓库,以备本地的其它项目作为依赖使用
mvn deploy    复制最终的包至远程仓库,共享给其它开发人员和项目(通常和一次正式的发布相关)








3:Maven 配置文件


setting.xml 文件是 Maven 的默认配置文件,其默认路径为:<Maven 安装目录>/conf/settings.xml。

如果需要修改 Maven 配置,直接修改 setting.xml 并保持即可。

例如:想要修改本地仓库位置可以按如下配置,这样,所有通过 Maven 下载打包的 jar 包都会存储在 D:\maven\repo 路径下。

<settings xmlns="http://maven.apache.org/SETTINGS/1.1.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.1.0 http://maven.apache.org/xsd/settings-1.1.0.xsd">
  <localRepository>D:\maven\repo<localRepository/>     <- 修改本地仓库位置

   <mirror>
        <id>alimaven</id>
        <name>aliyun-maven</name>
        <mirrorOf>central</mirrorOf>
        <url>http://maven.aliyun.com/nexus/content/groups/public</url>  <-阿里加速
    </mirror>
    </mirrors>





</settings>


<settings>
	<!--<localRepository>E:\Decument\Maven\repository</localRepository>-->
	<localRepository>K:\repository</localRepository>
	<mirrors>
		<mirror>
			<id>alimaven</id>
			<name>aliyun maven</name>
			<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
			<mirrorOf>central</mirrorOf>
		</mirror>
		<mirror>
            <id>alimaven</id>
            <mirrorOf>central</mirrorOf>
            <name>aliyun maven</name>
            <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
        </mirror>
		<mirror>
			<id>alimaven</id>
			<name>aliyun maven</name>
			<url>https://maven.aliyun.com/nexus/content/groups/public/</url>  
			<mirrorOf>nexus</mirrorOf>
		</mirror>
		<mirror>
			<id>ibiblio</id>
			<mirrorOf>central</mirrorOf>
			<name>Human Readable Name for this Mirror.</name>
			<url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
		</mirror>
		<mirror>
			<id>jboss-public-repository-group</id>
			<mirrorOf>central</mirrorOf>
			<name>JBoss Public Repository Group</name>
			<url>http://repository.jboss.org/nexus/content/groups/public</url>
		</mirror>
		<mirror>
			<id>central</id>
			<name>Maven Repository Switchboard</name>
			<url>http://repo1.maven.org/maven2/</url>
			<mirrorOf>central</mirrorOf>
		</mirror>
		<mirror>
			<id>repo2</id>
			<mirrorOf>central</mirrorOf>
			<name>Human Readable Name for this Mirror.</name>
			<url>http://repo2.maven.org/maven2/</url>
		</mirror>

	</mirrors>
	<servers>
		<server>
			<id>pwp</id>
			<username>admin</username>
			<password>t0daytech_2017</password>
		</server>
	</servers>
	<profiles>
		<profile>
		  <id>central</id>
		  <repositories>
			<repository>
			  <id>central</id>
			  <url>http://repo1.maven.org/maven2/</url>
			  <releases>
				<enabled>true</enabled>
			  </releases>
			</repository>
		  </repositories>
		</profile>
		<profile>
		  <id>repo2</id>
		  <repositories>
			<repository>
			  <id>repo2</id>
			  <url>http://repo2.maven.org/maven2/</url>
			  <releases>
				<enabled>true</enabled>
			  </releases>
			</repository>
		  </repositories>
		</profile>
		<profile>
		  <id>ibiblio</id>
		  <repositories>
			<repository>
			  <id>ibiblio</id>
			  <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>
			  <releases>
				<enabled>true</enabled>
			  </releases>
			</repository>
		  </repositories>
		</profile>
		<profile>
		  <id>jboss-public-repository-group</id>
		  <repositories>
			<repository>
			  <id>jboss-public-repository-group</id>
			  <url>http://repository.jboss.org/nexus/content/groups/public</url>
			  <releases>
				<enabled>true</enabled>
			  </releases>
			</repository>
		  </repositories>
		</profile>
		<profile>
			<id>alimaven</id>
			<repositories>
				<repository>
					<id>alimaven</id>
					<name>local private nexus</name>
					<tent/groups/public/</url>
					<releases>
						<enabled>true</enabled>
					</releases>
					<snapshots>
						<enabled>false</enabled>
					</snapshots>
				</repository>
			</repositories>
			<pluginRepositories>
				<pluginRepository>
				<id>alimaven</id>
				<name>local private nexus</name>
				<url>https://maven.aliyun.com/nexus/content/groups/public/</url>  
				<releases>
					<enabled>true</enabled>
				</releases>
				<snapshots>
					<enabled>false</enabled>
				</snapshots>
				</pluginRepository>
			</pluginRepositories>
		</profile>

		<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>


二:Ecplise  maven 配置

image

image

image


三:Eclipse  maven  创建 父子项目


1、创建父级工程

操作一、点击file->Project 或者 使用 Alt +Shift +N

image

操作二、在搜索框中搜索maven 点击Maven Project->Next

image

操作三、红框处打勾后,点Next

image

image


操作四、填入以下信息,点完成

image

image



2、创建Maven子工程  --->   jar包子工程创建


操作一、在parent项目名上右击,选择如下,点击New Maven Module Project

image

操作二、勾选后,输入模块名称,点击Next

image


操作三、点击finish完成


image

pom.xml

<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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.alan.Spring5Demo</groupId>
  <artifactId>Spring5Demo</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>pom</packaging>
  <modules>
  	<module>Spring5DemoUnit1</module>
  	<module>Spring5DemoWeb</module>
  </modules>
   <dependencies>

        <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
        <!-- https://mvnrepository.com/artifact/org.springframework/spring-beans -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</artifactId>
            <version>5.3.10</version>
        </dependency>



        <!-- https://mvnrepository.com/artifact/org.springframework/spring-core -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
            <version>5.3.10</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.3.10</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.springframework/spring-expression -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-expression</artifactId>
            <version>5.3.10</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13</version>
            <scope>compile</scope>
        </dependency>


    </dependencies>
</project>



3.创建Maven子工程  --->  war包子工程创建


操作一、在parent项目名上右击,选择如下,点击New Maven Module Project

image

操作二、勾选后,输入模块名称,点击Next


image

image



image


点击完成后我们会看到新建的war项目有错误,查看Problem控制台会报一个web.xml丢失的错误,因为它自带的骨架就是没有web.xml文件

image

创建web.xml文件

image

image


image

image

我们会看到新建的web.xml文件中空空如也

image


我们接下来拷贝一个web.xml的头进去

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

</web-app>

image

至此war工程就完成了。


(2)自动添加(自动添加,一步搞定,文件头什么的都带了)

操作:在war项目名上右键,依次选择,点击小奶瓶Generate… 错误就自动解决了
















posted @ 2023-03-19 10:05  一品堂.技术学习笔记  阅读(31)  评论(0编辑  收藏  举报