zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    H5图片上传、压缩
    数据库基本操作
    数组遍历
    CURL
    获取IP
    Memcached的实战笔记
    修bug总结 (基于java语言)
    java开发工作的总结
    多线程测试类
    可清除的单例对象获取类
  • 原文地址:https://www.cnblogs.com/homeword/p/7118803.html
Copyright © 2011-2022 走看看