Maven 标准目录结构

本文介绍了Maven标准目录结构和生命周期。Maven2提供缺省标准目录模板,如src/main/resources和src/test/resources,使用模板可使pom.xml更简洁。还介绍了创建标准目录模板的命令。同时引用文章讨论Maven生命周期,包括validate、compile等主要阶段,阶段间存在依赖关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Maven 标准目录结构

好的目录结构可以使开发人员更容易理解项目,为以后的维护工作也打下良好的基础。Maven2根据业界公认的最佳目录结构,为开发者提供了缺省的标准目录模板。Maven2的标准目录结构如下:

src/main/javaApplication/Library sources
src/main/resourcesApplication/Library resources
src/main/filtersResource filter files
src/main/assemblyAssembly descriptors
src/main/configConfiguration files
src/main/scriptsApplication/Library scripts
src/main/webappWeb application sources
src/test/javaTest sources
src/test/resourcesTest resources
src/test/filtersTest resource filter files
src/siteSite
LICENSE.txtProject's license
NOTICE.txtNotices and attributions required by libraries that the project depends on
README.txt

Project's readme

使用目录模板,可以使 pom.xml 更简洁。因为 Maven2 已经根据缺省目录,预定义了相关的动作,而无需人工的干预。以 resources 目录为例:

  • src/main/resources,负责管理项目主体的资源。在使用Maven2执行compile之后,这个目录中的所有文件及子目录,会复制到target/classes目录中,为以后的打包提供了方便。
  • src/test/resources,负责管理项目测试的资源。在使用Maven2执行test-compile之后,这个目录中的所有文件及子目录,会复制到target/test-classes目录中,为后续的测试做好了准备。

这些动作在 Maven1 中,是需要在 maven.xml 中使用<preGoal>或<postGoal>来完成的。如今,完全不需要在pom.xml中指定就能够自动完成。在src和test都使用resources,方便构建和测试,这种方式本就已是前人的经验。通过使用Maven2,使这个经验在开发团队中得到普及。

创建标准目录模板,可以通过如下命令:

mvn archetype:create -DgroupId=com.codeline.commons -DartifactId=codelineCommons

groupId和artifactId的含义与Maven1中的含义一样,参数artifactId的值会作为项目根目录的名字。除了建立相应的目录之外,Maven2还会创建缺省的pom.xml。

Maven2也考虑到:不同类型的项目需要拥有不同的目录结构。如创建web项目,可以使用命令:

mvn archetype:create -DgroupId=com.mycompany.app
-DartifactId=my-webapp
-DarchetypeArtifactId=maven-archetype-webapp

Maven 生命周期

Maven生命周期已经在另一篇博客中介绍过了(http://www.cnblogs.com/haippy/archive/2012/07/04/2576453.html),这里引用IBM developerworks 的文章再一次讨论Maven 的生命周期。

在Maven2中有了明确的生命周期概念,而且都提供与之对应的命令,使得项目构建更加清晰明了。主要的生命周期阶段:

  • validate,验证工程是否正确,所有需要的资源是否可用。
  • compile,编译项目的源代码。
  • test-compile,编译项目测试代码。
  • test,使用已编译的测试代码,测试已编译的源代码。
  • package,已发布的格式,如jar,将已编译的源代码打包。
  • integration-test,在集成测试可以运行的环境中处理和发布包。
  • verify,运行任何检查,验证包是否有效且达到质量标准。
  • install,把包安装在本地的repository中,可以被其他工程作为依赖来使用
  • deploy,在整合或者发布环境下执行,将最终版本的包拷贝到远程的repository,使得其他的开发者或者工程可以共享。
  • generate-sources,产生应用需要的任何额外的源代码,如xdoclet。

如果要执行项目编译,那么直接输入:mvn compile即可,对于其他的阶段可以类推。阶段之间是存在依赖关系(dependency)的,如test依赖test-compile。在执行mvn test时,会先运行mvn test-compile,然后才是mvn test。

 

 

转:https://www.cnblogs.com/haippy/archive/2012/07/05/2577233.html

### Maven 标准目录结构解释 Maven 项目遵循一种标准化的目录结构,这种结构被称为 **Standard Directory Layout**。它旨在使开发人员能够快速理解项目的布局并简化构建过程。以下是 Maven 项目的典型目录结构及其功能描述: #### 1. `src/main/java` 此目录用于存储应用程序的主要 Java 源代码文件[^1]。这些源码会被编译到目标类路径下。 ```plaintext src/main/java/com/example/app/Main.java ``` #### 2. `src/main/resources` 该目录包含运行时所需的资源文件,例如配置文件、属性文件或其他静态数据。这些资源会随同编译后的 `.class` 文件一起打包到最终的 JAR 或 WAR 中。 ```plaintext src/main/resources/application.properties ``` #### 3. `src/test/java` 测试相关的 Java 源代码位于此处,通常包括单元测试和集成测试代码。默认情况下,Maven 使用 Surefire 插件来执行这些测试。 ```java // Example test class located under src/test/java public class AppTest { @Test public void shouldAnswerWithTrue() { assertTrue(true); } } ``` #### 4. `src/test/resources` 类似于 `src/main/resources`,但专门用于测试阶段所需的各种资源文件。它们不会被打包到生产环境中。 ```plaintext src/test/resources/test-config.xml ``` #### 5. `target` 这是一个自动生成的目录,包含了编译输出以及生成的工件(如 JAR/WAR 文件)。开发者不应手动修改这个目录中的内容。 ```plaintext target/classes/ target/generated-sources/ target/surefire-reports/ ``` #### 6. `pom.xml` 这是 Maven 构建的核心配置文件,定义了项目的元信息、依赖项以及其他插件设置。通过编辑 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 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <!-- Project coordinates --> <groupId>com.example</groupId> <artifactId>maven-demo-project</artifactId> <version>1.0-SNAPSHOT</version> <!-- Dependencies section --> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> </dependencies> </project> ``` --- ### 注意事项 当使用特定工具或框架时,可能还需要满足额外的要求。例如,在某些场景下,如果需要 RocksDB 支持,则应在 `pom.xml` 添加如下依赖: ```xml <dependency> <groupId>org.rocksdb</groupId> <artifactId>rocksdbjni</artifactId> <version>7.0.3</version> </dependency> ``` 另外需要注意的是,不同版本的 Maven 和其插件可能存在兼容性问题。比如 jmeter-maven-plugin 的某个版本可能仅支持特定范围内的 Maven 版本[^2]。 最后,对于企业级应用开发而言,除了基础的标准目录外,还可以考虑引入更高层次的企业平台框架,如 CUBA Platform 或 Spring Framework 来提升生产力[^3]。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值