springboot项目打成公共jar包被其他项目单独引用(包含mybatis-plus)

需求:公司需要对不同模块单独开发,单独引用,上网找了打包引用的方式,因为需要在打包的项目中进行数据库操作,网上找的不详细,在此记录一下,比如:A项目打成公共jar包被其他单独(B、C 等等)项目引用

一,A项目进行打包

1,更换打包方式
不使用springboot自带的打包插件进行打包,因为springboot打包插件打出来的jar包第一目录为Boot-INF,会导致无法引用。
springboot打包方式为:

<build>
    <finalName>${project.artifactId}</finalName>
	<plugins>
      <plugin>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
   </plugins>
</build>

更改为maven打包方式:

<build>
    <finalName>${project.artifactId}</finalName>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>1.8</source> <!--指明源码用的Jdk版本-->
                <target>1.8</target> <!--指明打包后的Jdk版本-->
            </configuration>
        </plugin>
    </plugins>
</build>

下面为整个pom.xml文件:

<?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>org.example</groupId>
    <artifactId>accounting-balanceUpdate</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.13.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--lombok简化java代码-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.20</version>
        </dependency>

        <!-- mysql -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
            <version>5.1.46</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.9</version>
        </dependency>

        <!--Mybatis-Plus启动器-->
        <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.1.1</version>
        </dependency>
        
        <!--Mybatis-Plus不集成springboot依赖-->
<!--        
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus</artifactId>
            <version>3.1.1</version>
        </dependency>
-->
    </dependencies>

    <build>
        <finalName>${project.artifactId}</finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source> <!--指明源码用的Jdk版本-->
                    <target>1.8</target> <!--指明打包后的Jdk版本-->
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

2,项目目录结构
在这里插入图片描述
就是一个正常的springboot集成mybatis-plus项目,记得在启动类上加注解@MapperScan(“accounting.balanceupdate.mapper”)
3,进行打jar包
我使用的是idea进行打包
在这里插入图片描述
先clean再package进行打包,在项目目录的target目录下面可以看到jar包。

注意: 如果不想使用springboot集成mybatis-plus,想单独使用mybatis-plus的话,需要把springboot启动类,application.yml文件和springboot的相关依赖进行剔除,但我们连接数据库的配置一般写在yml文件中(在代码中直接连接数据库的除外),这时没有了数据库连接配置,想单独启动是不行的,可以直接打包放到别的项目中进行引用,前提是这个项目中连接的数据库和jar包中连接的数据库一致,同样可以成功进行数据库操作。

二,B项目引入A项目jar包

1,新建libs目录,放入jar包
在这里插入图片描述
2,配置依赖

<dependency>
    <groupId>org.example</groupId>
    <artifactId>accounting-balanceUpdate</artifactId>
    <version>1.0-SNAPSHOT</version>
    <scope>system</scope>
    <systemPath>${pom.basedir}/libs/accounting-balanceUpdate.jar</systemPath>
</dependency>

3,配置yml文件

mybatis-plus:
  mapper-locations: classpath*:mapper/*.xml

注意:必须要加classpath后面的*,代表扫描项目下所有的resources目录

4,mybatis-plus配置
在springboot启动类上加注解或者在配置类中加上此注解,不然无法扫描的目录类

@MapperScan({"com.tjcloud.designer.mapper", "accounting.balanceupdate.mapper"})
@ComponentScan({"com.tjcloud.designer", "accounting.balanceupdate"})

到此完成!!!

三,测试引用

在这里插入图片描述
TdAUserRealbalanceService为A项目jar包中的一个接口类
注意: jar包和主体项目的配置类不能重复,比如:在主体项目中已经使用MybatisPlusConfig配置类了,在jar包中就不可以在引入,不然项目会启动不成功,包配置覆盖的错误。
org.springframework.beans.factory.BeanDefinitionStoreException: Failed to parse configuration class [com.tjcloud.designer.WriteOffApplication]; nested exception is org.springframework.context.annotation.ConflictingBeanDefinitionException: Annotation-specified bean name ‘mybatisPlusConfig’ for bean class [accounting.billwriteoff.config.MybatisPlusConfig] conflicts with existing, non-compatible bean definition of same name and class [com.tjcloud.designer.config.MybatisPlusConfig]

要创建一个Spring Boot项目并整合MyBatis-Plus,你可以按照以下步骤进行操作: 1. 首先,在你的项目的pom.xml文件中添加MyBatis-Plus和MySQL驱动的依赖。你可以引用和中提的示例代码来配置pom.xml文件。这将确保你的项目具有使用MyBatis-Plus和MySQL的必要依赖。 2. 接下来,创建一个用于定义数据库连接和其他配置的配置文件。你可以在Spring Boot的配置文件(application.properties或application.yaml)中添加以下配置信息: - 数据库连接配置:包括数据库的URL、用户名和密码等信息。 - MyBatis-Plus配置:你可以配置MyBatis-Plus的一些属性,比如自动填充、逻辑删除等。 你可以根据你的实际需求进行配置。 3. 然后,创建数据库表对应的实体类。你可以使用Java类来表示数据库表,并在类上使用注解来映射数据库字段和表。 4. 接下来,创建Mapper接口和Mapper.xml文件。Mapper接口用于定义数据库操作的方法,而Mapper.xml文件用于编写具体的SQL语句。你可以使用MyBatis-Plus的自动注入功能来简化这一过程。通过继承MyBatis-Plus的BaseMapper接口,你可以自动获得常见的CRUD操作方法。 5. 最后,编写业务逻辑代码并注入Mapper。在你的Service类中,你可以注入Mapper接口,并使用它来调用数据库操作方法。你可以根据你的实际需求编写其他业务逻辑代码。 运行你的Spring Boot项目后,你应该能够看到控制台输出一系列信息,表明Spring Boot项目成功整合了MyBatis-Plus。你可以参考中提的示例代码来验证整合结果。 总结起来,创建Spring Boot项目并整合MyBatis-Plus的步骤包括:配置pom.xml文件、创建配置文件、定义实体类、创建Mapper接口和Mapper.xml文件、编写业务逻辑代码。你可以根据所提的参考内容来详细了解每个步骤的具体实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值