maven基础教程

1.创建一个简单的项目并打包执行

1.1创建一个maven命令

[plain]  view plain copy print ?
  1. <span style="font-size:14px;">mvn archetype:create -DgroupId=org.sonatype.mavenbook.ch03 -DartifactId=simple -DpackageName=org.sonatype.mavenbook</span>  
会看到生成一个simple项目,目录格式如下:

[html]  view plain copy print ?
  1. <span style="font-size:14px;">simple/   与artifactId匹配的目录  
  2.     simple/pom.xml 项目对象模型 (POM)描述了这个项目,配置了插件,声明了依赖  
  3.      /src/  
  4.         /src/main/   存放项目的源码java和资源文件  
  5.                /main/java  
  6.         /src/test/ 测试的java测试类和测试的资源文件  
  7.                 /test/java</span>  

Maven Archtype插件生成了一个简单的类org.sonatype.mavenbook.App,它是一个仅有13行代码的Java,所做的只是在main方法中输出一行消息:

[java]  view plain copy print ?
  1. <span style="font-size:14px;">package org.sonatype.mavenbook;  
  2. /** 
  3. * Hello world! 
  4. * 
  5. */  
  6. public class App  
  7. {  
  8.    public static void main( String[] args )  
  9.    {  
  10.       System.out.println( "Hello World!"    );  
  11.    }  
  12. }</span>  
1.2构建与输出

在simple的项目下包含pom.xml的目录下运行mvn install。提示build success表示构建成功。

你已经创建了,编译了,测试了,打包了,并且安装了(installed)最简单的Maven项目。在命令行运行它以向你自己验证这个程序能工作。

[plain]  view plain copy print ?
  1. <span style="font-size:14px;">$ java -cp target/simple-1.0-SNAPSHOT.jar org.sonatype.mavenbook.App  
  2. Hello World!</span>  
2.依赖包的解释

[html]  view plain copy print ?
  1. <span style="font-size:14px;"><groupId>org.springframework</groupId>  
  2. <artifactId>spring-aop</artifactId>  
  3. <version>3.0.3.RELEASE</version></span>  
groupId
   团体,公司,小组,组织,项目,或者其它团体。团体标识的约定是它以创建这个项目的组织名称的逆向域名(reverse domain name)开头。来自spring的项目以org.springframework开头的groupId,而Apache Software的项目以org.apache开头的groupId。
artifactId
   在groupId下的表示一个单独项目的唯一标识符,spring-aop代表了其单独模块。
version
   一个项目的特定版本。发布的项目有一个固定的版本标识来指向该项目的某一个特定的版本。而正在开发中的项目可以用一个特殊的标识,这种标识给版本加上一个“SNAPSHOT”的标记。

3.基本命令

3.1基本命令

1.由于pom可以从超级pom和父类的pom中继承,依赖传递,所以需要查看有效的pom的命令是:mvn help:effective-pom

2. mvn dependency:sources 故名思义,有了它,你就不用到处找源码了,运行一下,你项目里所依赖的jar包的源码就都有了

3.编译源代码: mvn compile 
4. 编译测试代码:mvn test-compile    
5. 运行测试:mvn test   
6. 产生site:mvn site   
7. 打包:mvn package   
8. 在本地Repository中安装jar:mvn install 
9. 清除产生的项目:mvn clean   
10. 生成eclipse项目:mvn eclipse:eclipse  
11. 生成idea项目:mvn idea:idea  
12. 组合使用goal命令,如只打包不测试:mvn -Dtest package   
13. 编译测试的内容:mvn test-compile  
14. 只打jar包: mvn jar:jar  
15. 只测试而不编译,也不测试编译:mvn test -skipping compile -skipping test-compile 
      ( -skipping 的灵活运用,当然也可以用于其他组合命令)  
16. 清除eclipse的一些系统设置:mvn eclipse:clean 
17.mvn -e            显示详细错误 信息. 
18.mvn validate        验证工程是否正确,所有需要的资源是否可用。 
19.mvn test-compile    编译项目测试代码。 。 
20.mvn integration-test     在集成测试可以运行的环境中处理和发布包。 
21.mvn verify        运行任何检查,验证包是否有效且达到质量标准。     
22.mvn generate-sources    产生应用需要的任何额外的源代码,如xdoclet。 
23.mvn -v 显示版本 
24.mvn help:describe -Dplugin=help 使用 help 插件的  describe 目标来输出 Maven Help 插件的信息。 
25.mvn help:describe -Dplugin=help -Dfull 使用Help 插件输出完整的带有参数的目标列 
26.mvn help:describe -Dplugin=compiler -Dmojo=compile -Dfull 获取单个目标的信息,设置mojo参数和plugin 参数。此命令列出了Compiler 插件的compile 目标的所有信息 
27.mvn help:describe -Dplugin=exec -Dfull 列出所有 Maven Exec 插件可用的目标 
28.mvn dependency:resolve 打印出已解决依赖的列表 
29.mvn dependency:tree 打印整个依赖树 

3.2命令详解

1. mvn help:describe 你是否因为记不清某个插件有哪些goal而痛苦过,你是否因为想不起某个goal有哪些参数而苦恼,那就试试这个命令吧,它会告诉你一切的. 参数: 1. -Dplugin=pluginName 2. -Dgoal(或-Dmojo)=goalName:与-Dplugin一起使用,它会列出某个插件的goal信息,如果嫌不够详细,同样可以加-Ddetail.(注:一个插件goal也被认为是一个 “Mojo”) 下面大家就运行mvn help:describe -Dplugin=help -Dmojo=describe感受一下吧!


2. mvn archetype:generate 你是怎么创建你的maven项目的?是不是像这样:mvn archetype:create -DarchetypeArtifactId=maven-archetype-quickstart -DgroupId=com.ryanote -Dartifact=common,如果你还再用的话,那你就out了,现代人都用mvn archetype:generate了,它将创建项目这件枯燥的事更加人性化,你再也不需要记那么多的archetypeArtifactId,你只需输入archetype:generate,剩下的就是做”选择题”了.


3. mvn tomcat:run 用了maven后,你再也不需要用eclipse里的tomcat来运行web项目(实际工作中经常会发现用它会出现不同步更新的情况),只需在对应目录(如/ryanote)里运行 mvn tomat:run命令,然后就可在浏览器里运行http://localhost:8080/ryanote查看了.如果你想要更多的定制,可以在pom.xml文件里加下面配置: 01 02 03 04 org.codehaus.mojo 05 tomcat-maven-plugin 06 07 /web 08 9090 09 10 11 12 当然你也可以在命令里加参数来实现特定的功能,下面几个比较常用: 1. 跳过测试:-Dmaven.test.skip(=true) 2. 指定端口:-Dmaven.tomcat.port=9090 3. 忽略测试失败:-Dmaven.test.failure.ignore=true 当然,如果你的其它关联项目有过更新的话,一定要在项目根目录下运行mvn clean install来执行更新,再运行mvn tomcat:run使改动生效.


4. mvnDebug tomcat:run 这条命令主要用来远程测试,它会监听远程测试用的8000端口,在eclipse里打开远程测试后,它就会跑起来了,设断点,调试,一切都是这么简单.上面提到的那几个参数在这里同样适用.

4.dependencyManagement和Profile

        Maven 还我们提供了一个dependencyManagement元素,用来提供了一种方式来统一依赖版本号。dependencyManagement元素一 般用在顶层的父POM。使用pom.xml中的dependencyManagement元素能让你在子项目中引用一个依赖而不用显式的列出版本号。 Maven会沿着父子层次向上走,直到找到一个拥有dependencyManagement元素的项目,然后它就会使用在这个 dependencyManagement元素中指定的版本号,这样就解决了修改依赖版本号不完全的问题。

        Maven的Profile元素可以为一个特殊的环境自定义一个特殊的构建,使得不同环境间构建的可移植性成为可能。比如要使用 production profile来运行mvn install,你需要在命令行传入-Pproduction参数,这里production是profile的id。要验证production profile覆盖了默认的Compiler插件配置,可以像这样以开启调试输入(-X) 的方式运行Maven。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值