时间:2021-05-02
前言:
以前我们在建项目的时候, 要么将所有的package建在一个项目里面, 在处理引用的时候, 真的很方便. 不用担心, 有些东西配置不到或者读取不到.
或者, 将package独立出去, 到一个项目中或者子项目中. 这时候, 项目中的引用处理, 还是有些麻烦的. 不过好处更多, 不再表述.
在 idea 里面, 推荐使用 多模块 建项目, 而不再是 eclipse 里面的那种方式. 那这里, 就试着将一个springboot 的项目拆分到子模块中去, 看看效果如何.
项目拆分:
1. 目录变化
2. 父项目
父pom.xml理论上来说, 应该是对子项目中的引用进行一个约束, 主要是版本约束.
所以父 pom.xm 中, 应该使用dependencymanagement 来约束 子项目中 jar 包版本.
然后对于一些子项目都用得着的引用, 可以提到 父项目中去.
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> <packaging>pom</packaging> <name>parent</name> <description>demo project for spring boot</description> <parent> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-parent</artifactid> <version>1.5.9.release</version> <relativepath/> <!-- lookup parent from repository --> </parent> <modules> <module>pojo</module> <module>web</module> <module>dao</module> <module>service</module> <module>simpl</module> </modules> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> <druid.version>1.1.3</druid.version> <mybatis.boot.starter.version>1.3.1</mybatis.boot.starter.version> <mysql.connector.java.version>5.1.44</mysql.connector.java.version> </properties> <dependencymanagement> <dependencies> <dependency> <groupid>com.alibaba</groupid> <artifactid>druid</artifactid> <version>${druid.version}</version> </dependency> <dependency> <groupid>org.mybatis.spring.boot</groupid> <artifactid>mybatis-spring-boot-starter</artifactid> <version>${mybatis.boot.starter.version}</version> </dependency> <dependency> <groupid>mysql</groupid> <artifactid>mysql-connector-java</artifactid> <version>${mysql.connector.java.version}</version> </dependency> </dependencies> </dependencymanagement> <!--申明依赖关系--> <dependencies> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>3. 子项目 - pojo
3.1 pom.xml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <parent> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> </parent> <groupid>cn.elvinle</groupid> <artifactid>pojo</artifactid> <version>0.0.1-snapshot</version> <packaging>jar</packaging> <name>pojo</name> <description>demo project for spring boot</description> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> </properties> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>3.2 db实体
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 package cn.elvinle.pojo; /** * @author: elvin */ public class user { private int id; private string name; public int getid() { return id; } public void setid(int id) { this.id = id; } public string getname() { return name; } public void setname(string name) { this.name = name; } }对于pojo和dao中的内容, 可以使用mybatis逆向工程生成, 可以省去很多麻烦.
4. 子项目 - dao
4.1 pom.xml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <parent> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> </parent> <groupid>cn.elvinle</groupid> <artifactid>dao</artifactid> <version>0.0.1-snapshot</version> <packaging>jar</packaging> <name>dao</name> <description>demo project for spring boot</description> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> </properties> <dependencies> <!-- 内部引用 --> <dependency> <groupid>cn.elvinle</groupid> <artifactid>pojo</artifactid> <version>0.0.1-snapshot</version> </dependency> <!-- 外部引用 --> <!-- https://mvnrepository.com/artifact/com.alibaba/druid --> <dependency> <groupid>com.alibaba</groupid> <artifactid>druid</artifactid> </dependency> <dependency> <groupid>mysql</groupid> <artifactid>mysql-connector-java</artifactid> </dependency> <dependency> <groupid>org.mybatis.spring.boot</groupid> <artifactid>mybatis-spring-boot-starter</artifactid> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>4.2 mapper
usermapper.java:
? 1 2 3 public interface usermapper { public list<user> getall(); }usermapper.xml:
? 1 2 3 4 5 6 7 <?xml version="1.0" encoding="utf-8" ?> <!doctype mapper public "-//mybatis.org//dtd mapper 3.0//en" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="cn.elvinle.dao.mapper.usermapper" > <select id="getall" resulttype="cn.elvinle.pojo.user"> select * from user </select> </mapper>5. 子项目 - service
5.1 pom.xml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <parent> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> </parent> <groupid>cn.elvinle</groupid> <artifactid>service</artifactid> <version>0.0.1-snapshot</version> <packaging>jar</packaging> <name>service</name> <description>demo project for spring boot</description> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupid>cn.elvinle</groupid> <artifactid>pojo</artifactid> <version>0.0.1-snapshot</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>5.2 userservice.java
? 1 2 3 public interface userservice { public list<user> getall(); }6. 子项目 - simpl
6.1 pom.xml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <parent> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> </parent> <groupid>cn.elvinle</groupid> <artifactid>simpl</artifactid> <version>0.0.1-snapshot</version> <packaging>jar</packaging> <name>simpl</name> <description>demo project for spring boot</description> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupid>cn.elvinle</groupid> <artifactid>pojo</artifactid> <version>0.0.1-snapshot</version> </dependency> <dependency> <groupid>cn.elvinle</groupid> <artifactid>service</artifactid> <version>0.0.1-snapshot</version> </dependency> <dependency> <groupid>cn.elvinle</groupid> <artifactid>dao</artifactid> <version>0.0.1-snapshot</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>6.2 usersimpl
? 1 2 3 4 5 6 7 8 9 10 11 12 13 @service public class usersimpl implements userservice { @autowired private usermapper usermapper; @override public list<user> getall() { system.out.println("usersimpl getall"); return usermapper.getall(); } }7. 子项目 - web
关键的地方来了.
7.1 pom.xml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 <?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <parent> <groupid>cn.elvinle</groupid> <artifactid>parent</artifactid> <version>0.0.1-snapshot</version> </parent> <groupid>cn.elvinle</groupid> <artifactid>web</artifactid> <version>0.0.1-snapshot</version> <packaging>jar</packaging> <name>web</name> <description>demo project for spring boot</description> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <project.reporting.outputencoding>utf-8</project.reporting.outputencoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupid>cn.elvinle</groupid> <artifactid>simpl</artifactid> <version>0.0.1-snapshot</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-maven-plugin</artifactid> </plugin> </plugins> </build> </project>7.2 application.yml
? 1 2 3 4 5 6 7 8 9 10 11 12 13 server: context-path: /parent port: 8080 mybatis: config-location: /mapper/*.xml spring: datasource: username: root password: root url: jdbc:mysql://localhost:3306/shop?useunicode=true&characterencoding=utf-8 driver-class-name: com.mysql.jdbc.driver7.3 控制器
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 @restcontroller @requestmapping("api") public class apicontroller { @autowired private userservice userservice; @requestmapping("index") public list<user> index(){ list<user> all = userservice.getall(); return all; } }到目前为止, 没什么特别的, 都是正常修改, 接下来, 会出现与不分模块不同的地方.
7.4 入口处修改
? 1 2 3 4 5 6 7 8 @componentscan({"cn.elvinle"}) @springbootapplication public class webapplication { public static void main(string[] args) { springapplication.run(webapplication.class, args); } }这时候, 如果直接运行起程序, 是不会成功访问的. 原因在于, mybatis的自动化配置和自动化创建, 没有支持到多模块中.
这时候, 需要我们手动进行配置和创建.
7.5 mybatis java 配置
? 1 2 3 4 5 6 7 8 9 10 11 12 13 <!-- mybatis 的工厂 --> <bean id="sqlsessionfactory" class="org.mybatis.spring.sqlsessionfactorybean"> <property name="datasource" ref="datasource" /> <property name="configlocation" value="classpath:mybatis/sqlmapconfig.xml"/> <!-- 自动扫描mapping.xml文件 --> <!--<property name="mapperlocations" value="classpath:mapper/*.xml" />--> </bean> <!-- dao接口所在包名,spring会自动查找其下的类 --> <bean id="mapperscannerconfigurer" class="org.mybatis.spring.mapper.mapperscannerconfigurer"> <property name="basepackage" value="cn.elvinle.bookshop.mapper" /> <property name="sqlsessionfactorybeanname" value="sqlsessionfactory"/> </bean>可以对照着上面的配置文件, 进行java配置
mybatisconfig:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 @configuration public class mybatisconfig { @value("${mybatis.config-location}") private string mapperlocationpattern; @bean @configurationproperties(prefix = "spring.datasource") public datasource datasource(){return new com.alibaba.druid.pool.druiddatasource(); } @bean(name="sqlsessionfactory") public sqlsessionfactory sqlsessionfactory() throws exception{ sqlsessionfactorybean sqlsessionfactorybean = new sqlsessionfactorybean(); sqlsessionfactorybean.setdatasource(datasource()); pathmatchingresourcepatternresolver resolver = new pathmatchingresourcepatternresolver(); sqlsessionfactorybean.setmapperlocations(resolver.getresources(mapperlocationpattern)); return sqlsessionfactorybean.getobject(); } }mybatismapperscannerconfig:
? 1 2 3 4 5 6 7 8 9 10 11 @configuration @autoconfigureafter(mybatisconfig.class) @mapperscan("cn.elvinle.dao.mapper") public class mybatismapperscannerconfig { public mapperscannerconfigurer mapperscannerconfigurer(){ mapperscannerconfigurer mapperscannerconfigurer = new mapperscannerconfigurer(); mapperscannerconfigurer.setsqlsessionfactorybeanname("sqlsessionfactory"); mapperscannerconfigurer.setbasepackage("cn.elvinle.dao.mapper"); return mapperscannerconfigurer; } }ok, 到这里, 就可以把程序跑起来了, 看一下结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/elvinle/p/8177825.html
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
已有的springcloud+mybatis项目升级为mybatis-plus项目模块目录将mybatis依赖替换为mybatis-plus修改配置文件实体类如
一般maven多模块工程结构如下图,图中分为dao数据层和上层web层(当然还可以有service层),在进行多模块划分的时候,一般将dao层采用jar进行打包
我就废话不多说了,大家还是直接看代码吧~补充知识:Springboot整合mybatis继承mapper接口,扩展自己的dao接口这里主要介绍Mybatis-G
Maven多模块项目,适用于一些比较大的项目,通过合理的模块拆分,实现代码的复用,便于维护和管理。尤其是一些开源框架,也是采用多模块的方式,提供插件集成,用户可
Maven多模块项目,适用于一些比较大的项目,通过合理的模块拆分,实现代码的复用,便于维护和管理。尤其是一些开源框架,也是采用多模块的方式,提供插件集成,用户可