pom.xml配置文件详解

简介

setting.xml主要用于配置maven的运行环境等一系列通用的属性,是全局级别的配置文件;而pom.xml主要描述了项目的maven坐标,依赖关系,开发者需要遵循的规则,缺陷管理系统,组织和licenses,以及其他所有的项目相关因素,是项目级别的配置文件。

基础配置

一个典型的pom.xml文件配置如下:

"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.0http://maven.apache.org/xsd/maven-4.0.0.xsd">  

      
    4.0.0</modelVersion>  

      
    com.winner.trade</groupId>  

      
    trade-coreId>  

      
    1.0.0-SNAPSHOT</version>  

      
    jar>  

      
    ...</classifier>  

      
      

          
          

          
              
            com.winner.tradeId>  
            trade-test</artifactId>  
            1.0.0-SNAPSHOT>  

              
              
            test</scope>  

              
            false>  

              
              
                  
                    org.slf4j</groupId>  
                    slf4j-apiId>  
                </exclusion>  
            >  

        </dependency>  

    >  

      
      
        UTF-8</file.encoding>  
        1.5.source.version>  
        1.5</java.target.version>  
    >  

    ...  
</project>  

一般来说,上面的几个配置项对任何项目都是必不可少的,定义了项目的基本属性。

这里有必要对一个不太常用的属性classifier做一下解释,因为有时候引用某个jar包,classifier不写的话会报错。

classifier元素用来帮助定义构件输出的一些附属构件。附属构件与主构件对应,比如主构件是 kimi-app-2.0.0.jar,该项目可能还会通过使用一些插件生成 如kimi-app-2.0.0-javadoc.jar (Java文档)、 kimi-app-2.0.0-sources.jar(Java源代码) 这样两个附属构件。这时候,javadoc、sources就是这两个附属构件的classifier,这样附属构件也就拥有了自己唯一的坐标。

classifier的用途在于:

  1. maven download javadoc / sources jar包的时候,需要借助classifier指明要下载那个附属构件

  2. 引入依赖的时候,有时候仅凭groupId、artifactId、version无法唯一的确定某个构件,需要借助classifier来进一步明确目标。比如JSON-lib,有时候会同一个版本会提供多个jar包,在JDK1.5环境下是一套,在JDK1.3环境下是一套:
    pom.xml配置文件详解_第1张图片
    引用它的时候就要注明JDK版本,否则maven不知道你到底需要哪一套jar包:

  
           net.sf.json-lib</groupId>  
           json-libId>  
            2.4</version>  
           jdk15>  
</dependency>  

构建配置

  

      
    myPorjectName</finalName>  

      
    ${basedir}/target</directory>  

      
      
    installGoal>  

      
      
      
        ../filter.properties</filter>  
    >  

      
      
          

              
              
              
            resources</targetPath>  

              
            true>  

              
            src/main/resources</directory>  

              
              
                **/*.properties</include>  
                **/*.xml</include>  
            >  

              
              
                jdbc.properties</exclude>  
            >  

        </resource>  
    >  

      
      
          
              
              
              
              
              
        </testResource>  
    Resources>  

      
    ${basedir}\src\main\java</sourceDirectory>  

      
    ${basedir}\src\main\scripts  
    SourceDirectory>  

      
    ${basedir}\src\test\java</testSourceDirectory>  

      
    ${basedir}\target\classesDirectory>  

      
    ${basedir}\target\test-classes  
    </testOutputDirectory>  

      
      
      
      

          
          
          
          
          
          
            org.apache.maven.wagonId>  
            wagon-ssh</artifactId>  
            2.8>  
        </extension>  

    >  

      
      
          
            </groupId>  
            maven-assembly-pluginId>  
            2.5.5</version>  

              
              
                  

                      
                    assembly>  

                      
                    package</phase>  

                      
                      
                        single>  
                    </goals>  

                      
                    false>  

                </execution>  
            >  

              
              
                ${finalName}</finalName>  
                falseAssemblyId>  
                assembly.xml</descriptor>  
            >  

              
              
            false</extensions>  

              
              
                ...>  
            </dependencies>  

              
            true>  

        </plugin>  
    >  

      
      
      
      
        ...</plugins>  
    Management>  

</build>  

pom里面的仓库与setting.xml里的仓库功能是一样的。主要的区别在于,pom里的仓库是个性化的。比如一家大公司里的setting文件是公用的,所有项目都用一个setting文件,但各个子项目却会引用不同的第三方库,所以就需要在pom里设置自己需要的仓库地址。

  
  
  

      
      

          
          
        true</uniqueVersion>  

         repo-id >  
         repo-name</name>  
        file://${basedir}/target/deploy >  
          

    </repository>  

      
      
        >  
          
          
          
          
    </snapshotRepository>  

      
      

          
         site-id >  

          
         site-name</name>  

          
        scp://svn.baidu.com/banseon:/var/www/localhost/banseon-web </url>  

    >  

      
      
      

      
      

          
          

          
          

          
          

          
          

    </relocation>  

      
      
      
    >  

</distributionManagement>  

仓库配置

  
  

      
      

          
          

              
              

              
              
              
              

              
              
              

        </releases>  

          
          
          
          
            >  
              
              
        </snapshots>  

          
         repo-id >  

          
         repo-name</name>  

          
        http://192.168.1.169:9999/repository/ >  

          
          
          
          
         default</layout>  

    >  

</repositories>  

  
  

      
      

</pluginRepositories>  

profile配置

  
  

      
      
          
          

              
            false</activeByDefault>  

              
            1.7>  

              
              

                  
                Windows XP</name>  

                  
                Windows>  

                  
                x86</arch>  

                  
                5.1.2600>  

            </os>  

              
              
              

                  
                mavenVersion>  

                  
                2.0.3</value>  

            >  

              
              
              

                  
                /usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/</exists>  

                  
                /usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/>  

            </file>  

        >  
          
          
          
          
          
          
          
          
          
          
    </profile>  

profile配置项在setting.xml中也有,是pom.xml中profile元素的裁剪版本,包含了id,activation, repositories, pluginRepositories和 properties元素。这里的profile元素只包含这五个子元素是因为setting.xml只关心构建系统这个整体(这正是settings.xml文件的角色定位),而非单独的项目对象模型设置。如果一个settings中的profile被激活,它的值会覆盖任何其它定义在POM中或者profile.xml中的带有相同id的profile。
pom.xml中的profile可以看做pom.xml的副本,拥有与pom.xml相同的子元素与配置方法。它包含可选的activation(profile的触发器)和一系列的changes。例如test过程可能会指向不同的数据库(相对最终的deployment)或者不同的dependencies或者不同的repositories,并且是根据不同的JDK来改变的。只需要其中一个成立就可以激活profile,如果第一个条件满足了,那么后面就不会在进行匹配。

报表配置

  
  
  

      
      

      
      

      
      

          
              
              
              
              
              
                  
                    http://java.sun.com/j2se/1.5.0/docs/api/</link>  
                >  
            </configuration>  
              
              
              
              

                  
                  

                      
                    sunlink>  

                      
                      

                      
                      

                      
                      
                        javadoc</report>  
                    >  

                </reportSet>  

            Sets>  

        </plugin>  

    >  

</reporting>     

环境配置

  
  

      
     jira </system>  

      
     http://jira.clf.com/</url>  

Management>  

  
  

      
      

      
      

      
      

          
          

              
              

              
              

              
              

              
              

              
              

              
            
</notifier> > </ciManagement>

项目信息配置

  
banseon-maven </name>  

  
http://www.clf.com/ </url>  

  
  
  
A maven project to study maven. >  

  
  

      
      

</prerequisites>  

  
>  

  
  

      
      

          
         Demo </name>  

          
         [email protected]>  

          
         clf@126.com</subscribe>  

          
         [email protected]>  

          
         http:/hi.clf.com/</archive>  

    List>  

</mailingLists>  

  
  

      
      

          
         HELLO WORLD >  

          
         banseon </name>  

          
         [email protected]>  

          
          

          
          
             Project Manager</role>  
            Architect >  
        </roles>  

          
         demo>  

          
        http://hi.clf.com/ </organizationUrl>  

          
          
             No >  
        </properties>  

          
         -5>  

    </developer>  

>  

  
  

      
      
          
          
          
          
          
          
          
          
    </contributor>  

>  

  
  
  

      
      

          
         Apache 2 </name>  

          
        http://www.clf.com/LICENSE-2.0.txt </url>  

          
         repo>  

          
         Abusiness-friendly OSS license </comments>  

    >  

</licenses>  

  
  

      
    scm:svn:http://svn.baidu.com/banseon/maven/</connection>  

      
    scm:svn:http://svn.baidu.com/banseon/maven/  
    </developerConnection>  

      
    >  

      
     http://svn.baidu.com/banseon</url>  

>  

  
  

      
     demo </name>  

      
     http://www.clf.com/</url>  

>  

你可能感兴趣的:(计算机其他)