Maven实战03_Maven使用入门

1:pom.xml

Maven项目的核心文件,非常重要。POM(Project Object Model)项目对象模型,其定义了项目的基本信息,用于描述项目如何构建,声明项目依赖等等。

创建一个最简单的pom文件:pom.xml,首先新建文件夹HelloWorld,在里面新建一个pom。xml,然后新建一个包(src/main/java),在新建一个包com.soulprayer.maven.maven_study,然后进入该文件夹,打开pom.xml文件(推荐使用Notepad++ / Sublime),并输入下列代码清单中的内容:

pom.xml代码清单

<?xml version="1.0" encoding="UTF-8"?>
<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>
    <groupId>com.soulprayer.maven</groupId>
    <artifactId>maven-study</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>war</packaging>
    <name>Maven Hello World Project</name>
</project>
pom.xml代码清单说明:
  • 第一行是XML头,指定该xml文档的版本和编码方式
  • <project></project>所有pom.xml的根元素,声明了一些pom相关的命名空间及xsd元素约束。
  • <modelVersion></modelVersion> 指定了当前POM模型的版本,对于Maven2一级Maven3来说,只能是4.0.0
  • <groupId></groupId>定义了项目属于哪个组,这个组往往和项目所在的组织或公司存在关联
  • <artifactId></artifactId>定义了当前Maven项目在组中唯一的ID,
  • <version></version>定义了当前Maven项目的版本
  • <name> 定义了当前项目更加友好清晰的名称

备注:groupIdartifactId、version 三者共同确定唯一坐标,也就是说这个项目在整个Maven仓库中是唯一的.

优点:

      它能让项目对象模型最大程度地与实际代码相独立,即解耦或者正交性。这在很大程度上避免了Java代码和POM代码相互影响,比如当项目需要升级版本时,只需要修改POM,而不需要修改Java代码,而在POM稳定之后,日常的Java代码开发工作基本不涉及POM的修改。

2:编写主代码

项目主代码和测试代码不同,项目的主代码会被打包到最终的构件中(如jar),而测试代码只在测试时用到,不会被打包。默认情况下,Maven项目的主代码位于/src/main/java目录中,我们遵循Maven的约定,创建该目录,然后在该目录下创建文件 com/soulprayer/maven/maven-study/HelloWorld.java。

代码清单如下:

package main.java.com.soulprayer.maven.maven_study;

public class HelloWorld {
    
    public String sayHello() {
        return "Hello Maven";
    }
    
    public static void main(String[] args) {
        System.out.println(new HelloWorld().sayHello());
    }

}

这是一个很简单的Java类,它有一个sayHello()方法,返回一个String,同时还有一个Main方法,创建一个HelloWorld实例,调用sayHello()方法,并将结果输出到控制台上。

关于该Java代码有三点需要注意:

  • 应该把项目主代码放到src/main/java目录下(约定大于配置),这样就不需要额外的配置,Maven会自动搜索该目录找到项目主代码
  • 该Java类的报名是com.soulprayer.maven,这与之前在POM中定义的groupId和artifaceId相吻合。一般来说,项目中的Java类的包都应该基于项目的groupId和artifactId,这样更加清晰,也更加符合逻辑。
  • pom.xml的位置很重要,不要乱放,要放到和src平级的目录下,这样groupId才会生效,否则又会多一层。

代码编写完毕及满足上述条件后,在项目根目录下运行命令mvn cleam compile 会得到如图所示的输出结果。

image

clean会先告诉Maven清理输出目录 target/,compile告诉Maven编译项目主代码,从输出中看到Maven首先执行了clean:clean任务,删除 target/目录。默认情况下,Maven构建的输出都在target/目录中,接着执行resources:resources任务(未定义项目资源,略过),最后执行compiler:compile任务,将项目主代码编译至target/classes目录。

3:编写测试代码

为了使项目结构保持清晰,主代码与测试代码应该分开来放,放置于独立目录中,主代码的目录是/src/main/java,则对应的测试代码的目录是/src/test/java,因此,在编写测试用例之前,要先创建该目录,然后为其添加Junit依赖,本文使用Junit进行测试。

修改的POM的代码清单如下:

<?xml version="1.0" encoding="UTF-8"?>
<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>
    <groupId>com.soulprayer.maven</groupId>
    <artifactId>maven_study</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>Maven Hello World Project</name>
    
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.7</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
    
</project>

新增元素说明  

  • <dependencies></dependencies>在该元素下可以包含多个<dependency>元素以声明项目的依赖,这里就通过groupId、artifactId、version三个元素定义了唯一的junit依赖标识。然后Maven会依据conf/setting.xml中的配置去中央仓库进行下载。
  • <scope></scope>依赖范围:test表示该依赖只对测试有效,换句话说,测试代码中import Junit代码是没问题的,但是如果在主代码中用import Junit代码,就会造成编译错误,如果不声明依赖范围,默认的就是compile,表示对主代码和测试代码都生效

编写测试类 HelloWorldTest.java,代码清单:

package test.java.com.soulprayer.maven.maven_study;

import org.junit.Test
import static org.junit.Assert.assertEquals;

public class HelloWorldTest {
    
    @Test
    public void testSayHello(){
        HelloWorld helloWorld = new HelloWorld();
        String result = helloWorld.sayHello();
        assetEquals("Hello Maven",result);
    }

}

一个典型的单元测试包含三个步骤:

  • 准备测试类及数据
  • 执行要测试的行为
  • 检查结果

使用Maven执行测试

image

可以看到,Tests run(测试运行)1个,Failures(失败):0,Error(错误)0,Skipped(跳过):0

4:打包和运行

将项目进行编译、测试之后,下一个重要步骤就是打包(package)。HelloWorld的POM中没有指定打包类型,使用默认打包类型jar,简单地执行命令mvn clean package进行打包,可以看到如下输出:

image

实际上jar插件的jar目标将项目主代码打包成一个名为maven_study-1.0-SNAPSHOT.jar的文件。该文件也位于target/输出目录中,它是根据artifact-version.jar规则进行命名的。还可以使用finalName来自定义该文件的名称,这个会在后面说。

进行到这里,我们得到了项目的输出,一个jar文件,如果有需要的话,就可以复制这个jar文件到其他项目的Classpath中从而使用HelloWorld类。但是,如何才能让其他的maven项目直接引用这个jar呢,这里需要一个安装的步骤,执行mvn clean instal,效果图如下:

image

在打包之后,又执行了安装任务install。从输出中的红框中可以看到,该任务将项目的jar安装到了本地Maven仓库中,可以打开相应的文件查看到HelloWorld项目的pom和jar。之前的Junit的pom和jar也是同样的道理,只有构件被下载到本地仓库之后,才能由Maven项目所使用。

到目前为止,都没有运行HelloWorld项目,在HelloWorld中是存在一个main方法的。默认打包生成jar是不能够直接运行的,因为带有main方法的类信息不会添加到manifest中(打开jar文件的 META-INF / MANIFEST.MF文件,将无法看到Main-Class一行)。为了能够生成可执行的jar文件,需要借助maven-shade-plugin,错误图与插件配置如下:

image

插件配置代码清单:

<build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>1.2.1</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>com.soulprayer.maven.maven_study.HelloWorld</mainClass>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

代码清单说明:

  • <build></build>:构建需要相关插件
  • <plugins></plugins>:同<dependencies></dependencies>,在该标签下可以包含多个<plugin>
  • <plugin></plugin>:具体插件,同<dependency>,利用其中的三者确定插件唯一标识。
  • <executions></executions>:同<dependencies></dependencies>,其标签下可以包含多个<execution>运行规则,我们指定了<phase>阶段为package的运行规则为实现了org.apache.maven.plugins.shade.resource.ManifestResourceTransformer这个接口将会把指定类:com.soulprayer.maven.maven_study.HelloWorld,作为程序入口类,并将其放入到程序清单中。

执行效果图

image

posted @ 2017-07-04 22:18  读书改变命运  阅读(1060)  评论(0编辑  收藏  举报