Maven(4)-利用intellij idea创建maven 多模块项目

本文通过一个例子来介绍利用maven来构建一个多模块的jave项目。开发工具:intellij idea。

一、项目结构

multi-module-project是主工程,里面包含两个模块(Module):

web-app是应用层,用于界面展示,依赖于web-service参的服务。

web-service层是服务层,用于给app层提供服务。

二、构建项目

2.1 Parent Project

新建一个空白标准maven project(不要选择Create from archetype选项)

填写项目坐标

得到一个标准的maven项目,因为该项目是作为一个Parent project存在的,可以直接删除src文件夹。

2.2 增加web-app模块(Module)

选择从archetype创建(选择webapp选项)

groupId和version继承自Parent project,这里只需要填写artifactId即可。

2.3增加web-service模块

用同样的方法创建web-service模块(不过该模块是一个空白maven标准项目,不要从archetype创建)

2.4 得最终项目结构

2.5 关键几点

Parent project和各个Module拥有独立pom文件,他们之间的关系后续会专门写文章介绍。

Parent project用于组织不同的Module,不实现逻辑

Module集成Parent project的groupId和version,Module只需要指定自己的artifactId即可。

三、添加项目依赖

上面的操作是添加web-app对web-service模块的依赖,完成上述操作后web-Service中public的类已经在web-app模块中可见了。但是这个时候在app模块使用了service模块中的类,通过maven进行编译(compile)的时候还是会报错XX找不到(XX为service模块的类),要解决这个问题需要在app的pom中增加对service的依赖:

XML 复制代码
<dependency>
<groupId>com.cnblogs.kmpp</groupId>
<artifactId>web-service</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>

以上,项目依赖的添加已经完成

四、开始编程

4.1 web-service模块编程

在web-service模块中增加一个Service类(SimpleService.java)

4.2 web-app模块编程

在web-app模块增加一个Servlet,并且调用web-service模块的SimpleService类的getServiceDescription方法。

4.3 配置Servlet

XML 复制代码
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
<display-name>Archetype Created Web Application</display-name>

<servlet>
<servlet-name>Simple</servlet-name>
<servlet-class>com.cnblogs.kmpp.SimpleServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Simple</servlet-name>
<url-pattern>/simple-servlet</url-pattern>
</servlet-mapping>
</web-app>

五、运行

在web-app的pom中增加j2ee的依赖,以及jetty插件的依赖。运行jetty。​

在浏览器中输入:http://localhost:8080/web-app/simple-servlet

得到运行结果:

六、结束

至此,本文完整演示了使用maven构建多模块项目。


Maven(4)-利用intellij idea创建maven 多模块项目

https://blog.51cto.com/u_15283585/5015653

相关推荐
yuanyxh4 分钟前
commonmark.js 源码阅读(二) - Inline Parser
前端·javascript·html
韩明君6 分钟前
前端学习笔记——Promis.All
前端·笔记·学习
斯~内克21 分钟前
Vite + Vue 工程中,为什么需要关注 `postcss.config.ts`?
前端·vue.js·postcss
蜗牛快跑21326 分钟前
使用 Cursor 从 0 到 1 开发一个全栈 chatbox 项目
前端·人工智能·ai·ai编程
Python涛哥1 小时前
前端流行框架Vue3教程:24.动态组件
前端·javascript·vue.js
劲爽小猴头1 小时前
HTML5快速入门-表单&实用标签
前端·html·html5
举一个梨子zz2 小时前
Java—— IO流的应用
java·开发语言·intellij-idea·io·需求分析·file
蓝胖子的多啦A梦2 小时前
Vue+css实现扫描动画效果(使用@keyframes scan)
前端·css·vue.js·keyframes scan
沐土Arvin2 小时前
Web 安全进阶:前端信封加解密技术详解
前端·javascript·安全·设计模式
码上敲享录2 小时前
前端如何播放flv视频
前端·音视频