0


Maven中常用命令以及idea中使用maven指南

文章目录

Maven 常用命令

compile

compile 是maven 工程的编译命令,作用是将src/main/java 下的文件编译为class 文件输出到target
目录下。

test

test 是maven 工程的测试命令 mvn test,会执行src/test/java 下的单元测试类。

clean

clean 是maven 工程的清理命令,执行clean 会删除target 目录及内容。

package

package 是maven 工程的打包命令,对于java 工程执行package 打成jar 包,对于web 工程打成war
包。

install

install 是maven 工程的安装命令,执行install 将maven 打成jar 包或war 包发布到本地仓库。从运行结果中,可以看出:
当后面的命令执行时,前面的操作过程也都会自动执行,

Maven 指令的生命周期

maven 对项目构建过程分为三套相互独立的生命周期,请注意这里说的是“三套”,而且“相互独立”,这三套生命周期分别是:
Clean Lifecycle 在进行真正的构建之前进行一些清理工作。
Default Lifecycle 构建的核心部分,编译,测试,打包,部署等等。
Site Lifecycle 生成项目报告,站点,发布站点。

maven 的概念模型

Maven 包含了一个项目对象模型(Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标(goal)的逻辑。
在这里插入图片描述

  • 项目对象模型(Project Object Model)

一个maven 工程都有一个pom.xml 文件,通过pom.xml 文件定义项目的坐标、项目依赖、项目信息、插件目标等。

  • 依赖管理系统(Dependency Management System)

通过maven 的依赖管理对项目所依赖的jar 包进行统一管理。
比如:项目依赖junit4.13,通过在pom.xml 中定义junit4.13 的依赖即使用junit4.13,如下所示是junit4.13的依赖定义:

<dependency><!-- junit 的项目名称 --><groupId>junit</groupId><!-- junit 的模块名称 --><artifactId>junit</artifactId><!-- junit 版本 --><version>4.13</version><!-- 依赖范围:单元测试时使用junit --><scope>test</scope></dependency>
  • 一个项目生命周期(Project Lifecycle)

使用maven 完成项目的构建,项目构建包括:清理、编译、测试、部署等过程,maven 将这些过程规范为一个生命周期,如下所示是生命周期的各个阶段:
maven生命周期
maven 通过执行一些简单命令即可实现上边生命周期的各各过程,比如执行mvn compile 执行编译、执行mvn clean 执行清理。

  • 一组标准集合

maven 将整个项目管理过程定义一组标准,比如:通过maven 构建工程有标准的目录结构,有标准的生命周期阶段、依赖管理有标准的坐标定义等。

  • 插件(plugin)目标(goal)

maven 管理项目生命周期过程都是基于插件完成的。

idea 开发maven 项目

在实战的环境中,我们都会使用流行的工具来开发项目。

idea 的maven 配置

打开File->Settings 配置maven
idea中配置maven
依据图片指示,选择本地maven 安装目录,指定maven 安装目录下conf 文件夹中settings 配置文件。

idea 中创建一个maven 的web 工程

打开idea,选择创建一个新工程在这里插入图片描述
选择idea 提供好的maven 的web 工程模板选择idea提供模板
点击Next 填写项目信息
在这里插入图片描述
点击Next,此处不做改动。
在这里插入图片描述
点击Finish 后开始创建工程,耐心等待。
手动添加src/main/java 目录,如下图右键main 文件夹New -> Directory
在这里插入图片描述
创建一个新的文件夹命名为java,在新的文件夹java 上右键Make Directory as -> Sources Root,设置此目录为源代码目录。
在这里插入图片描述

在pom.xml 文件添加坐标

直接打开test666 工程的pom.xml 文件,再添加坐标。此处以springboot项目为例。
添加jar 包的坐标时,还可以指定这个jar 包将来的作用范围。
每个maven 工程都需要定义本工程的坐标,坐标是maven 对jar 包的身份定义,比如:入门程序的坐标定义如下:

<!--项目名称,定义为组织名+项目名,类似包名--><groupId>com.zjq</groupId><!-- 模块名称--><artifactId>test666</artifactId><!-- 当前项目版本号,snapshot 为快照版本即非正式版本,release 为正式发布版本--><version>1.0-SNAPSHOT</version><!--打包类型
      jar:执行package 会打成jar 包
      war:执行package 会打成war 包
      pom :用于maven 工程的继承,通常父工程设置为pom--><packaging>jar</packaging>

坐标的来源方式

添加依赖需要指定依赖jar 包的坐标,但是很多情况我们是不知道jar 包的的坐标,可以通过如下网站查询:
http://search.maven.org/
http://mvnrepository.com/
网站搜索示例:在这里插入图片描述
在这里插入图片描述

依赖范围

A 依赖B,需要在A 的pom.xml 文件中添加B 的坐标,添加坐标时需要指定依赖范围,依赖范围包括:

  • compile:编译范围,指A 在编译时依赖B,此范围为默认依赖范围。编译范围的依赖会用在编译、测试、运行,由于运行时需要所以编译范围的依赖会被打包。
  • provided:provided 依赖只有在当JDK 或者一个容器已提供该依赖之后才使用,provided 依赖在编译和测试时需要,在运行时不需要,比如:servlet api 被tomcat 容器提供。
  • runtime:runtime 依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如:jdbc 的驱动包。由于运行时需要所以runtime 范围的依赖会被打包。
  • test:test 范围依赖 在编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用, 比如:junit。由于运行时不需要所以test 范围依赖不会被打包。
  • system:system 范围依赖与provided 类似,但是你必须显式的提供一个对于本地系统中JAR

文件的路径,需要指定systemPath 磁盘路径,system 依赖不推荐使用。在这里插入图片描述
在工程中测试各个scope总结:

  • 默认引入 的jar 包----- compile 【默认范围 可以不写】(编译、测试、运行 都有效 )
  • servlet-api 、jsp-api ----- provided (编译、测试 有效, 运行时无效 防止和tomcat 下jar 冲突)
  • jdbc 驱动jar 包----- runtime (测试、运行 有效 )
  • junit ----- test (测试有效)

依赖范围由强到弱的顺序是:compile>provided>runtime>test
设置jdk 编译版本
本教程使用jdk1.8,需要设置编译版本为1.8,这里需要使用maven 的插件来设置: 在pom.xml 中加入:

<!--项目构建配置,配置编译、运行插件等。--><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.8.1</version><configuration><source>1.8</source><target>1.8</target><encoding>UTF-8</encoding></configuration></plugin><!--springboot项目需要指定如下maven插件--><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><mainClass>com.zjq.XXXApplication</mainClass></configuration></plugin></plugins><!--指定使用打包最终输出的文件名--><finalName>xxx-service</finalName></build>
<!--如果阿里云的仓库中找不到对应的插件会报错:Could not find artifact org.apache.tomcat.maven:tomcat8-maven-plugin:pom:3.0-r1655215 in aliyunmaven (https://maven.aliyun.com/repository/public)。
     需要配置如下插件仓库地址--><pluginRepositories><pluginRepository><id>alfresco-public</id><url>https://artifacts.alfresco.com/nexus/content/groups/public</url></pluginRepository><pluginRepository><id>alfresco-public-snapshots</id><url>https://artifacts.alfresco.com/nexus/content/groups/public-snapshots</url><snapshots><enabled>true</enabled><updatePolicy>daily</updatePolicy></snapshots></pluginRepository><pluginRepository><id>beardedgeeks-releases</id><url>http://beardedgeeks.googlecode.com/svn/repository/releases</url></pluginRepository></pluginRepositories>

编写servlet

在src/main/java 中创建HelloServlet访问后跳转到index.jsp
在这里插入图片描述
编写jsp
在这里插入图片描述
在web.xml 中配置servlet 访问路径

<servlet><servlet-name>helloServlet</servlet-name><servlet-class>com.zjq.test666.servlet.HelloServlet</servlet-class></servlet><servlet-mapping><servlet-name>helloServlet</servlet-name><url-pattern>/maven</url-pattern></servlet-mapping>

添加tomcat8 插件
在pom 文件中添加如下内容

<!--tomcat8插件--><plugin><groupId>org.apache.tomcat.maven</groupId><artifactId>tomcat8-maven-plugin</artifactId><version>3.0-r1655215</version><configuration><port>8088</port><path>/</path></configuration></plugin>

此时点击idea 最右侧Maven Projects, 就可以看到我们新添加的tomcat8 插件
双击tomcat8 插件下tomcat8:run 命令直接运行项目
在这里插入图片描述
也可以直接点击如图按钮,手动输入tomc8:run 命令运行项目在这里插入图片描述

maven 工程运行调试

点击如图所示选项,在弹出框中点击如图加号按钮找到maven 选项在这里插入图片描述
在弹出窗口中填写如下信息
在这里插入图片描述
完成后先Apply 再OK 结束配置后,可以在主界面找到我们刚才配置的操作名称。
在这里插入图片描述
如上图红框选中的两个按钮,左侧是正常启动,右侧是debug 启动。

本文内容到此结束了,
如有收获欢迎点赞👍收藏💖关注✔️,您的鼓励是我最大的动力。
如有错误❌疑问💬欢迎各位指出。
主页:共饮一杯无的博客汇总👨‍💻

保持热爱,奔赴下一场山海。🏃🏃🏃


本文转载自: https://blog.csdn.net/qq_35427589/article/details/134550576
版权归原作者 共饮一杯无 所有, 如有侵权,请联系我们删除。

“Maven中常用命令以及idea中使用maven指南”的评论:

还没有评论