【maven】多子模块maven模板工程archetype创建过程

最近项目里需要创建一个多模块(子工程)的模板项目,所以研究了一下maven的archetype plugin。

创建了一个包含多个子模块工程的项目模板。记录下过程。

 

 

一个模板工程任务就是创建一个或多个默认的工程,并为每个工程填充好默认的一些文件和配置。同时要抽象出生成的工程需要的一些属性,做到这些属性可动态配置。

在maven里通过定制的archetype来生成项目模板。maven本身内置了很多archetype 工程模板。通过
Java代码   收藏代码
  1. mvn archetype:generate  
 命令,mvn会列举出支持的所有项目模板。可以根据需求选择一个模板生成项目工程。
如果这些默认的模板还不够用,或者公司内部还希望定制自己个性化的工程模板,可以自己制作工程模板。
下面讲下archetype的制作过程。工程模板可以通过一个maven的archetype工程来定义。
下面的例子我编写的servicearchetype maven工程,是用来定义一个多模块的工程。

servicearchetype 工程总体结构


 

模板工程主要分为两个部分:

1.模板工程定义资源元文件

这些元文件是生成工程的时候需要用到的。放在src/main/resources/archetype-resources里。这里面的文件是生成模板工程是需要用到的元文件,一般也就是生成项目是默认填充的一些文件。

src/main/resources/archetype-resources里必须要有一个顶级pom文件(如果是单工程就是工程pom文件),同时子文件夹代表了模块定义。

这些文件可以写成velocity模板语法,在文件里使用一些变量,在生成文件的时候,可以选择通过velocity引擎渲染生成。

如以上例子里的src/main/resources/archetype-resources/common/pom.xml:

Java代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">  
  4.     <modelVersion>4.0.0</modelVersion>  
  5.     <groupId>${groupId}</groupId>  
  6.     <artifactId>${appName}.${artifactId}</artifactId>  
  7.     <version>${version}</version>  
  8.   
  9.     <name>${appName}.${artifactId}</name>  
  10.   
  11.     <dependencies>  
  12.     </dependencies>  
  13. </project>  

可以看到里面使用到了groupId,appName,artifactId等变量,这些变量在生成项目文件的时候会通过vilocity引擎进行替换。至于这些变量定义在哪里,可以看下一部分工程描述文件。

可以根据自己项目的类型和需要,定义任意的资源元文件,如java,xml,MANIFEST.MF等等。

 

 

2.模板工程定义描述文件META-INF/maven/archetype-meatdata.xml

有了工程定义元文件还不够。还需要一个东西来描述需要生成工程的结构和文件组成等等,这里可以通过archetype工程定义描述符来定义。

该文件是具体的生成工程规则的描述符。关于工程定义描述文件可以参考maven的官方文档:archetype-descriptor

如下是我写的工程定义描述:

 

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <archetype-descriptor name="servicearchetype">  
  3.     <requiredProperties>  
  4.         <requiredProperty key="appName">  
  5.             <defaultValue>helloworld</defaultValue>  
  6.         </requiredProperty>  
  7.         <requiredProperty key="groupId">  
  8.             <defaultValue>com.alibaba.china.app</defaultValue>  
  9.         </requiredProperty>  
  10.         <requiredProperty key="artifactId">  
  11.             <defaultValue>helloworld</defaultValue>  
  12.         </requiredProperty>  
  13.         <requiredProperty key="package">  
  14.             <defaultValue>com.alibaba.china.app</defaultValue>  
  15.         </requiredProperty>  
  16.     </requiredProperties>  
  17.     <modules>  
  18.         <module id="service.common" dir="common" name="service.common">  
  19.             <fileSets>  
  20.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  21.                     <directory>src/main/java</directory>  
  22.                     <includes>  
  23.                         <include>**/*.java</include>  
  24.                         <include>**/*.txt</include>  
  25.                     </includes>  
  26.                 </fileSet>  
  27.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  28.                     <directory>src/test/java</directory>  
  29.                     <includes>  
  30.                         <include>**/*.java</include>  
  31.                     </includes>  
  32.                 </fileSet>  
  33.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  34.                     <directory>src/main/resources</directory>  
  35.                     <includes>  
  36.                         <include>**/*.*</include>  
  37.                     </includes>  
  38.                 </fileSet>  
  39.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  40.                     <directory>src/test/resources</directory>  
  41.                     <includes>  
  42.                         <include>**/*.*</include>  
  43.                     </includes>  
  44.                 </fileSet>  
  45.                 <fileSet filtered="true" encoding="UTF-8">  
  46.                     <directory></directory>  
  47.                     <includes>  
  48.                         <include>pom.xml</include>  
  49.                     </includes>  
  50.                 </fileSet>  
  51.             </fileSets>  
  52.         </module>  
  53.         <module id="service.core" dir="core" name="service.core">  
  54.             <fileSets>  
  55.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  56.                     <directory>src/main/java</directory>  
  57.                     <includes>  
  58.                         <include>**/*.java</include>  
  59.                         <include>**/*.txt</include>  
  60.                     </includes>  
  61.                 </fileSet>  
  62.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  63.                     <directory>src/test/java</directory>  
  64.                     <includes>  
  65.                         <include>**/*.java</include>  
  66.                     </includes>  
  67.                 </fileSet>  
  68.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  69.                     <directory>src/main/resources</directory>  
  70.                     <includes>  
  71.                         <include>**/*.*</include>  
  72.                     </includes>  
  73.                 </fileSet>  
  74.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  75.                     <directory>src/test/resources</directory>  
  76.                     <includes>  
  77.                         <include>**/*.*</include>  
  78.                     </includes>  
  79.                 </fileSet>  
  80.                 <fileSet filtered="true" encoding="UTF-8">  
  81.                     <directory></directory>  
  82.                     <includes>  
  83.                         <include>pom.xml</include>  
  84.                     </includes>  
  85.                 </fileSet>  
  86.             </fileSets>  
  87.         </module>  
  88.         <module id="service.dal" dir="dal" name="service.dal">  
  89.             <fileSets>  
  90.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  91.                     <directory>src/main/java</directory>  
  92.                     <includes>  
  93.                         <include>**/*.java</include>  
  94.                         <include>**/*.txt</include>  
  95.                     </includes>  
  96.                 </fileSet>  
  97.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  98.                     <directory>src/test/java</directory>  
  99.                     <includes>  
  100.                         <include>**/*.java</include>  
  101.                     </includes>  
  102.                 </fileSet>  
  103.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  104.                     <directory>src/main/resources</directory>  
  105.                     <includes>  
  106.                         <include>**/*.*</include>  
  107.                     </includes>  
  108.                 </fileSet>  
  109.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  110.                     <directory>src/test/resources</directory>  
  111.                     <includes>  
  112.                         <include>**/*.*</include>  
  113.                     </includes>  
  114.                 </fileSet>  
  115.                 <fileSet filtered="true" encoding="UTF-8">  
  116.                     <directory></directory>  
  117.                     <includes>  
  118.                         <include>pom.xml</include>  
  119.                     </includes>  
  120.                 </fileSet>  
  121.             </fileSets>  
  122.         </module>  
  123.         <module id="service.deploy" dir="deploy" name="service.deploy">  
  124.             <fileSets>  
  125.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  126.                     <directory>src/main/resources</directory>  
  127.                     <includes>  
  128.                         <include>**/*.*</include>  
  129.                     </includes>  
  130.                 </fileSet>  
  131.                 <fileSet filtered="true" encoding="UTF-8">  
  132.                     <directory></directory>  
  133.                     <includes>  
  134.                         <include>pom.xml</include>  
  135.                     </includes>  
  136.                 </fileSet>  
  137.             </fileSets>  
  138.         </module>  
  139.         <module id="service.refrence" dir="refrence" name="service.refrence">  
  140.             <fileSets>  
  141.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  142.                     <directory>src/main/java</directory>  
  143.                     <includes>  
  144.                         <include>**/*.java</include>  
  145.                         <include>**/*.txt</include>  
  146.                     </includes>  
  147.                 </fileSet>  
  148.                 <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  149.                     <directory>src/test/java</directory>  
  150.                     <includes>  
  151.                         <include>**/*.java</include>  
  152.                     </includes>  
  153.                 </fileSet>  
  154.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  155.                     <directory>src/main/resources</directory>  
  156.                     <includes>  
  157.                         <include>**/*.*</include>  
  158.                     </includes>  
  159.                 </fileSet>  
  160.                 <fileSet filtered="true" encoding="UTF-8" packaged="false">  
  161.                     <directory>src/test/resources</directory>  
  162.                     <includes>  
  163.                         <include>**/*.*</include>  
  164.                     </includes>  
  165.                 </fileSet>  
  166.                 <fileSet filtered="true" encoding="UTF-8">  
  167.                     <directory></directory>  
  168.                     <includes>  
  169.                         <include>pom.xml</include>  
  170.                     </includes>  
  171.                 </fileSet>  
  172.             </fileSets>  
  173.         </module>  
  174.     </modules>  
  175. </archetype-descriptor>  
 

工程描述定义是个xml文件,符的几个重要标签定义解释如下

1.属性变量定义 
工程定义里需要用到的属性。

Xml代码   收藏代码
  1. <requiredProperties>  
  2.     <requiredProperty key="appName">  
  3.         <defaultValue>helloworld</defaultValue>  
  4.     </requiredProperty>  
  5.     <requiredProperty key="groupId">  
  6.         <defaultValue>com.alibaba.china.app</defaultValue>  
  7.     </requiredProperty>  
  8.     <requiredProperty key="artifactId">  
  9.         <defaultValue>helloworld</defaultValue>  
  10.     </requiredProperty>  
  11.     <requiredProperty key="package">  
  12.         <defaultValue>com.alibaba.china.app</defaultValue>  
  13.     </requiredProperty>  
  14. </requiredProperties>  
 


这些属性可以在资源元文件里的任意一个文件里通过${var}来引用,所以的元文件最终都可以选择通过velocity引擎来执行替换后生成。
默认的属性有:groupId,artifactId,packeage,version等。如在元文件里定义pom文件可以用:
     <groupId>${groupId}</groupId>
     <artifactId>${artifactId}</artifactId>
     <packaging>pom</packaging>
     <version>${version}</version>

2.项目子模块定义 
可选,在定义多工程时才需要。如:

Xml代码   收藏代码
  1. < modules>  
  2.        < module id"service.common" dir = "common" name"service.common" >  
  3.         .......  
  4.       < /module>  
  5.        < module id"service.core" dir = "core" name"service.core" >  
  6.         .......  
  7.       < /module>  
  8.       </modules>  

 

module有三个属性,解释如下:
id     :相当于工程的artifactId.
dir    :相当于工程源文件在archetype-resources里对应的directory.
name   :模块的名字.

3.项目文件集定义

fileSets/fileSet*  文件集合定义

Xml代码   收藏代码
  1. <fileSet filtered="true" encoding="UTF-8" packaged="true">  
  2.      <directory>src/main/java</directory>  
  3.      <includes>  
  4.           <include>**/*.java</include>  
  5.           <include>**/*.txt</include>  
  6.      </includes>  
  7. </fileSet>  
 


以上代表将archetype-resources里的src/main/java目录及内容作为新工程的目录和内容。里面的每个文件生成都会使用velocity模板引擎渲染,以替换变量。同时当packaged=true是表示会在生成这些新文件的时候,前面加上默认的包。
些属性做到可配置的变量。

 

 

总结

通过以上两部分定义之后,执行命令mvn clean install就将archetype安装到本地仓库了。

再通过如下命令:

Java代码   收藏代码
  1. mvn  archetype:generate -DarchetypeCatalog=local  

 选择你定义的工程archetype,同时通过交互输入需要的属性变量,就会默认生成好你定义的工程。

一下工程结构是我上面根据例子里定义的archetype生成的多子模块工程:


 

archtype定义工程源码见附件。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值