Maven的pom文件详解

​​​​​​POM基本项目信息

groupId:项目或者组织的唯一标志

artifactId:项目的通用名称

version:项目的版本

packaging:打包机制,如pom,jar,maven-plugin,ejb,war,ear,rar,par

name:用户描述项目的名称,无关紧要的东西,可选

url:应该是只是写明开发团队的网站,无关紧要,可选

POM依赖关系

依赖关系示例


    
      junit
      junit
      4.0
      jar
      test
      true
    
    
        com.alibaba.china.shared
        alibaba.apollo.webx
        2.5.0
        
          
            org.slf4j.slf4j-api
            com.alibaba.external
          
          ....
        
......

其中groupId, artifactId, version这三个组合标示依赖的具体工程,而且 这个依赖工程必需是maven中心包管理范围内的。

dependency里属性介绍

type:默认为jar类型,常用的类型有:jar,ejb-client,test-jar...,可设置plugins中的extensions值为true后在增加 新的类型,

scope:是用来指定当前包的依赖范围,maven的依赖范围

optional:设置指依赖是否可选,默认为false,即子项目默认都继承,为true,则子项目必需显示的引入,与dependencyManagement里定义的依赖类似 。

exclusions:如果X需要A,A包含B依赖,那么X可以声明不要B依赖,只要在exclusions中声明exclusion.

exclusion:是将B从依赖树中删除,如上配置,alibaba.apollo.webx不想使用com.alibaba.external  ,但是alibaba.apollo.webx是集成了com.alibaba.external,所以就需要排除掉.

parent的使用方法

如果一个工程是parent或者aggregation(即mutil-module的)的,那么必须在packing赋值为pom,child工程从parent继承的包括:dependencies,developers,contributors,plugin lists,reports lists,plugin execution with matching ids,plugin configuration

parent的使用方法如下:

 
    org.codehaus.mojo 
    my-parent 
    2.0 
    ../my-parent 
  

relativePath是可选的,maven会首先搜索这个地址,在搜索本地远程repositories之前.

dependencyManagement使用方法

dependencyManagement:是用于帮助管理chidren的dependencies的。例如如果parent使用dependencyManagement定义了一个dependencyon junit:junit4.0,那么 它的children就可以只引用 groupId和artifactId,而version就可以通过parent来设置,这样的好处就是可以集中管理 依赖的详情

modules:对于多模块的project,outer-module没有必需考虑inner-module的dependencies,当列出modules的时候,modules的顺序是不重要的,因为maven会自动根据依赖关系来拓扑排序,

modules例子如下 :

my-project

other-project

​​​​​​​properties信息

properties:是为pom定义一些常量,在pom中的其它地方可以直接引用

定义方式如下: 


      UTF-8
      1.5
      1.5

使用方式 如下 :

${file.encoding}

build属性设置

常用属性设置

defaultGoal:默认的目标,必须跟命令行上的参数相同,如:jar:jar,或者与时期parse相同,例如install

directory:指定build target目标的目录,默认为$(basedir}/target,即项目根目录下的target

finalName:指定去掉后缀的工程名字,例如:默认为${artifactId}-${version}

filters:用于定义指定filter属性的位置,例如filter元素赋值filters/filter1.properties,那么这个文件里面就可以定义name=value对,这个name=value对的值就可以在工程pom中通过${name}引用,默认的filter目录是${basedir}/src/main/fiters/

resources:描述工程中资源的位置 ​​​​​​​

     
        META-INF/plexus 
        false 
        ${basedir}/src/main/plexus 
         
          configuration.xml 
         
         
          **/*.properties 
         
      

targetPath:指定build资源到哪个目录,默认是base directory

filtering:指定是否将filter文件(即上面说的filters里定义的*.property文件)的变量值在这个resource文件有效,例如上面就指定那些变量值在configuration文件无效。

directory:指定属性文件的目录,build的过程需要找到它,并且将其放到targetPath下,默认的directory是${basedir}/src/main/resources

includes:指定包含文件的patterns,符合样式并且在directory目录下的文件将会包含进project的资源文件。

excludes:指定不包含在内的patterns,如果inclues与excludes有冲突,那么excludes胜利,那些符合冲突的样式的文件是不会包含进来的。

testResources:这个模块包含测试资源元素,其内容定义与resources类似,不同的一点是默认的测试资源路径是${basedir}/src/test/resources,测试资源是不部署的。​​​​​​​
plugins配置
 

 
        org.apache.maven.plugins 
        maven-jar-plugin 
        2.0 
        false 
        true 
         
          test 
         
        ... 
        ... 
      

 

extensions:true or false, 决定是否要load这个plugin的extensions,默认为true.

inherited:是否让子pom继承,ture or false 默认为true.

configuration:通常用于私有不开源的plugin,不能够详细了解plugin的内部工作原理,但使plugin满足的properties

dependencies:与pom基础的dependencies的结构和功能都相同,只是plugin的dependencies用于plugin,而pom的denpendencies用于项目本身。在plugin的dependencies主要用于改变plugin原来的dependencies,例如排除一些用不到的dependency或者修改dependency的版本等,详细请看pom的denpendencies.

executions:plugin也有很多个目标,每个目标具有不同的配置,executions就是设定plugin的目标,

         
            echodir 
             
              run 
             
            verify 
            false 
             
               
                Build Dir: ${project.build.directory} 
               
             
           

id:标识符

goals:里面列出一系列的goals元素,例如上面的run goal

phase:声明goals执行的时期,例如:verify

inherited:是否传递execution到子pom里。

configuration:设置execution下列表的goals的设置,而不是plugin所有的goals的设置.

仓库设置

Repositories:pom里面的仓库与setting.xml里的仓库功能是一样的。主要的区别在于,pom里的仓库是个性化的。





public

public

http://172.16.0.193:8081/nexus/content/groups/public/



true





true

always





​​​​​​​组件上传远程







user-snapshots

User Project SNAPSHOTS

http://172.16.0.193:8081/nexus/content/repositories/snapshots





user-release

User Project Release

http://172.16.0.193:8081/nexus/content/repositories/releases



对应setting.xml配置

Maven的pom文件详解_第1张图片

下节更精彩!可以看我首页进群你学习!!

 

你可能感兴趣的:(Maven学习教程,Maven,pom,详解)