在idea中创建多模块的SpringBoot项目

Posted 小鱼吃猫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在idea中创建多模块的SpringBoot项目相关的知识,希望对你有一定的参考价值。

在idea中创建多模块的SpringBoot项目

首先,了解下maven项目的三种打包方式:

1.war

打包为war包项目时,可以放在tomcat下运行

2.jar

打包成jar包就是要使用java -jar xxx.jar方式来运行,最常见的就是SpringBoot项目

3.pom

它只是用来做依赖管理,打包成的项目并不能直接运行。比如Springboot项目的父依赖以及再住上的依赖打包方式就是pom,因为它们只做依赖管理。

开始创建项目

总共创建三个module,分别为lyn4ever-web,lyn4ever-service,lyn4ever-dao。就这样做一个最简单的框架

1.第一步,创建父工程

1.1直接创建一个springboot项目(为了方便,当然普通的maven项目也可以,当你看懂原理后,随意玩),什么也不需要

titletitle
这一步只需要选择对应的版本就可以了,其他的可选可不选
title

1.2删除这个项目下的src文件夹,因为我们并不会在这里写代码

1.3在pom.xml中添加<packaging>pom</packaging>这一句

2.第二步,在刚才这个项目的根文件夹上鼠标右键,new->module->选择maven项目

  • 一定要在刚才这个项目的根文件夹上创建,因为这样它会自动为我们写好依赖关系(pom依赖关系),不然还要自己写.这时注意选择它的父依赖,如果没有就点击右边按纽选择刚才创建的modulepackage
    如果没有就点击右边按纽选择刚才创建的

  • 注意选择好在磁盘上的文件夹目录,默认情况下是正确的,直接跳过就好了.
    注意选择好在磁盘上的文件夹目录

  • idea自动为我们在父项目的pom文件中添加了如下一句
    idea自动为我们在父项
    而且,也可以看到,这个web项目的父依赖就是刚才创建的modulepackage项目
    个web项目的父依赖

3.第三步,这个web的项目就创建好了,我们就将这个子项目做为项目入口,即写一个springboot的启动类,只有这一个项目要写,其他的不用写.

package cn.lyn4ever.web.boot;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
  • 作为web层,我们还要引入springboot-web的依赖
 	<dependency>
 		<groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
       </dependency>

4.创建service子项目

和上一个一样,new->module->maven然后写好名字.接着在web项目中添加这个service的依赖,在web中的pom.xml中添加如下依赖:

	<dependency>
            <groupId>cn.lyn4ever</groupId>
            <artifactId>service</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

5.创建dao子项目

同样,也是创建子maven项目,但是这个dao层要连接数据库,我们就要引入mybatis和mysql相关依赖(由于我们最上一层用的是springboot依赖,所以完全可以引入mybatis依赖)。

  • 这些相关依赖可以引入到modulepackage的pom文件中,也可以引入到子模块中。我个人建议引入到子模块中,因为它并不是所有的子模块通用的,但是还是要使用父工程来管理这些依赖,怎么办?那就使用dependencyManagement,如果不明白这个做法的原理的小伙伴,请戳dependencies与dependencyManagement的区别
  • dao模块中的依赖
	<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
  • service层要依赖dao层,请在service的pom中添加依赖
 	<dependency>
            <groupId>cn.lyn4ever</groupId>
            <artifactId>dao</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
  • 在idea右边的maven管理中可以完全看到它们之间的依赖关系
    在idea右边的maven管

6.工程已经创建好了,我们就开始与代码进行测试吧。

  • 和我们通常写代码是一样的,web,service,dao层,请自行补全。(代码已上传到gitee,随时查看项目源代码地址

7.进行测试

7.1写好代码后运行Application.main()时报错

写好代码后运行Application.main()时报错
说明@Service没有扫描到, 所以没有这个bean,在Application.java上添加扫描注解@ComponentScan("cn.lyn4ever")
title
上边错就是说明扫描到mapper,加上注解@MapperScan("cn.lyn4ever.dao")

几个说明:

8.最重要的部分,打包上线和多人协作的情况处理

8.1 打包上线:

首先,你要明白。我们这么折腾了好一会儿,到底做了个什么?

  • service和dao模块其实就是一个被依赖的项目,真正的项目是web这个模块。

  • 所以,我们只需要打包web模块就可以了,但是web模块依赖service,service依赖dao。

  • maven中的所谓的依赖,就是要在仓库中寻找依赖。所以我们要先将service和dao这两个模块install到本地maven仓库中(只有这样,在打包web模块时,才能正确找到依赖,先dao,再service)。
    title
    如果报错如下

------------------------------------------------------------------------
[ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.2.2.RELEASE:repackage (repackage) on project dao: Execution repackage of goal org.springframework.boot:spring-boot-maven-plugin:2.2.2.RELEASE:repackage failed: Unable to find main class -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginExecutionException

将父项目中的这段代码复制到web模块中,因为这上sprinboot项目打包的插件。

	<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>	

当然,为了避免出现不必要的错误,我更建议直接对modulepackage这个父项目进行install
依次对dao和service执行了install后,可以在本地maven仓库中找到它们:
ao和service执行

然后对web模块进行打包,打包完成后,会在它的target文件夹下生成jar文件,我们运行这上jar文件
后对web模块进行打包

java -jar web-0.0.1-SNAPSHOT.jar

然后这个项目就可以上线了。

8.2多人协作时

我们使用压缩包的方式打开上边这个打包好的jar包,可以在里边找到刚才的service和dao打包成的jar包
jar包
也就是说,在对we模块打包时,是将本地仓库中的maven仓库中的service和dao的jar包打包了进去,如果是多人协作的话,最好创建一个maven私服,这样就会更加方便

  • 总结:
  • 1.在实际工作中,肯定不止一个web,service,dao。请在命名时做到见名知义。
  • 2.除了web层,其他的子模块最终会被打包成jar包,放在web包中,只需要运行这一个jar包就可以了
  • 3.父工程的打包方式一定要是pom,即
    <packaging>pom</packaging>

项目源代码地址

以上是关于在idea中创建多模块的SpringBoot项目的主要内容,如果未能解决你的问题,请参考以下文章

使用Maven构建多模块项目

使用Maven构建多模块项目

如何在 Visual Studio 2013 中创建多项目模板?

idea中创建多module的maven工程

在 Doctrine 中创建多对多关系的最佳实践。

185-在idea中创建springboot项目启动时出现java.lang.NoClassDefFoundError: ch/qos/logback/core/spi/LifeCycle错误(示例代