接上文内容,本节介绍Maven的聚合和继承。
从头阅读传送门
互联网时代,软件正在变得越来越复杂,开发人员通常会对软件划分模块,以获得清晰的设计、良好的分工及更高的可重用性。Maven的聚合特性能把多个模块聚合在一起构建,并促进各子模块通过继承父模块的pom配置来保持配置的一致。为了演示这些特性,本文的示例划分为数据持久层petstore-persist和petstore-web两个模块。
下面来介绍创建项目的过程,首先创建父模块perstore-parent。
File -> New -> Maven Project,简化一下流程,直接勾选创建简单项目,即跳过archetype的选择
下一步,填写Group Id和Artifact Id,注意作为父模块,打包类型(Packaging)必须选择pom。
完成后目录结构如下。
父模块除了构建文件pom.xml外没有实质内容,所以手动删除src目录,仅保留pom.xml文件,删除后目录结构如下:
接下来创建petstore-persist模块。在上图中petstore-parent上点击右键,选择New -> Project,在向导对话框中选择Maven Module,如下图:
下一步,这里仍然选择跳过archetype选项,模块名称填写petstore-persist
直接点击完成(Finish),完成后目录结构如下:
接下来创建Web子模块,重复“petstore-parent上点击右键,选择New -> Project,在向导对话框中选择Maven Module”步骤,但是不要勾选跳过archetype选择。填写模块名称后点击下一步。
archetype选择maven-archetype-webapp。
完成后目录结构如下:
在我的开发环境下,Maven的向导创建的Web模块版本是2.3,运行时会有一些兼容性问题,首先手动调整为3.0。
在项目上点击右键 -> Properties,并选择Project Facets菜单。现在选择3.0版本会提示错误,解决办法是先取消Dynamic Web Module选项,如下图:
点OK关闭对话框,修改petstore-web/src/main/webapps/WEB-INF/web.xml,如下:
petstore-web
从新打开Project Facets界面,勾选Dynamic Web Module选项,并选择版本号为3.0
然后点击Apply按钮保存设置。
然后切换到Java Build Path菜单,发现这里提示另一个错误,如下图:
解决办法是勾选JRE System Library[JavaSE-1.X],点击OK保存设置并关闭对话框,处理完成后项目中增加了一个WebContent目录,这对Maven项目来说是多余的,直接删除。
现在来解决Web模块上存在的红叉错误提示,查看详细信息,发现是“The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path”,说明是缺少编译的jar引用。在聚合结构中,通常在父模块的pom.xml中添加依赖,由其他子模块继承。这里有两种配置方法,第一种和普通项目相同,如下,子项目自动继承这些依赖。
petstore-parent/pom.xml
junit
junit
3.8.1
test
但这种方式不够灵活,在中大型项目中,通常有非常多的依赖项,项目中即使一个功能非常简单的基础模块也会继承全部依赖,显然是不合理的。所以这里使用第二种配置方式,即使用dependencyManagement元素,它既可以规范各子模块使用的依赖版本,也能允许各子模块按需添加依赖,不过,配置文件代码会更多一些。
petstore-parent/pom.xml
4.0.0
com.example
petstore-parent
0.0.1-SNAPSHOT
pom
petstore-persist
petstore-web
4.2.6.RELEASE
junit
junit
4.12
test
javax
javaee-web-api
7.0
provided
log4j
log4j
1.2.17
javax.servlet
jstl
1.2
org.apache.commons
commons-lang3
3.1
org.springframework
spring-core
${springframework.version}
org.springframework
spring-context
${springframework.version}
org.springframework
spring-test
${springframework.version}
org.springframework
spring-jdbc
${springframework.version}
org.springframework
spring-web
${springframework.version}
org.springframework
spring-webmvc
${springframework.version}
org.springframework
spring-beans
${springframework.version}
org.hibernate
hibernate-validator
5.2.4.Final
com.fasterxml.jackson.core
jackson-core
2.7.3
com.fasterxml.jackson.core
jackson-databind
2.7.3
c3p0
c3p0
0.9.1.2
mysql
mysql-connector-java
5.1.18
org.mybatis
mybatis
3.4.1
org.mybatis
mybatis-spring
1.3.0
petstore-persist/pom.xml
4.0.0
com.example
petstore-parent
0.0.1-SNAPSHOT
petstore-persist
junit
junit
org.springframework
spring-test
org.springframework
spring-core
org.springframework
spring-context
org.springframework
spring-beans
org.springframework
spring-jdbc
c3p0
c3p0
org.mybatis
mybatis
org.mybatis
mybatis-spring
mysql
mysql-connector-java
petstore-web/pom.xml
4.0.0
com.example
petstore-parent
0.0.1-SNAPSHOT
petstore-web
war
petstore-web Maven Webapp
http://maven.apache.org
junit
junit
javax
javaee-web-api
log4j
log4j
javax.servlet
jstl
org.apache.commons
commons-lang3
org.springframework
spring-core
org.springframework
spring-context
org.springframework
spring-test
org.springframework
spring-jdbc
org.springframework
spring-web
org.springframework
spring-webmvc
org.hibernate
hibernate-validator
com.fasterxml.jackson.core
jackson-core
com.fasterxml.jackson.core
jackson-databind
c3p0
c3p0
mysql
mysql-connector-java
org.mybatis
mybatis
org.mybatis
mybatis-spring
com.example
petstore-persist
0.0.1-SNAPSHOT
petstore-web
在上面的配置中,子模块中的依赖不需要在添加compile 编译、测试、运行都有效
test 测试依赖范围, 只对于测试有效, 编译主代码和运行项目时无法使用此类依赖
provided 对于编译和测试有效, 运行时无效
runtime 测试和运行时有效, 编译主代码无效, 如JDBC驱动
system 与provided范围一致, 通过systemPath元素关联本机文件路径, 用于Maven库外的jar包
回到项目中,添加依赖后红色警告消失,但这里还有一个步骤要做,否则Web模块可能无法运行。在petstore-web上点击右键 -> Maven -> Update Project...。
到这里,项目就全部搭建完成了。我们来编写一些测试代码,来检查项目是否可以正常运行。最终目录结构如下图,红色方框圈中的是添加或修改了代码的文件,各文件的源码打包提供,就不再一一粘贴了。
运行结果如下:
本节代码下载
总结
本节中介绍了通过Maven的聚合和继承特性创建复杂的多模块项目,虽然看起来步骤有些繁琐,但掌握后操作并不复杂。下一节开始进入SpringMVC和Mybatis的功能和整合介绍,包括增删改查等功能。
从头开始基于Maven搭建SpringMVC+Mybatis项目(1)
从头开始基于Maven搭建SpringMVC+Mybatis项目(2)
从头开始基于Maven搭建SpringMVC+Mybatis项目(3)
从头开始基于Maven搭建SpringMVC+Mybatis项目(4)