SpringBoot项目打jar包给其他Maven项目引用

背景
springboot项目要怎么打包,才能被其他项目GAV引入 打成springboot的可运行jar是不行的,要用maven插件打包。

例子
springboot项目被 mvn install 打包并安装到本地maven仓库后,被另外一个springboot项目引入,引入后发现JAR包存在却无法import JAR包中的类的问题。详细情况如下

两个项目

A(springboot)
B(springboot)
在这里插入图片描述

A的JAR包,看到了BOOT-INF,其他正常可以用的JAR包是没这个目录的。springboot打包的是springboot特有格式的jar包,即可以运行的fat jar,并不是传统的maven的JAR包,怎么解决

修改A项目的pom.xml,打包插件改一下,使用maven的就行了

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


    <!-- 要排除启动类 -->
  	<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
            <source>1.8</source> <!--指明源码用的Jdk版本-->
            <target>1.8</target> <!--指明打包后的Jdk版本-->
            <!-- 如果发现依然排除不了,考虑先clean再install-->
            <excludes>
                <exclude>
                    com/wyf/test/sub/AopFilterSpringinterceptorOrderingApplication.java
                </exclude>
            </excludes>
        </configuration>
    </plugin>
</plugins>

注意点
1、不要将启动类打包进去
注意!注意!注意! 要将启动类排除掉,或删掉或注释掉再打包。

如果不排除,它的@SpringBootApplication注解因包含了@ComponentScan,会导致项目B如果配置扫描jar包路径,并且扫描到这个启动类,会拉起A项目所有bean的实例化。详细的情况见下面的例子

A项目没有将springboot启动类排除并打包给B项目引入,B项目使用如下扫描规则

@ComponentScan(basePackages = {"B项目扫描路径", "A项目路径"},
        excludeFilters = {@ComponentScan.Filter(value = {ClassInA.class}, type = FilterType.ASSIGNABLE_TYPE)})

假设 "A项目路径" 里包含了A项目里的启动类,由于这个启动类有@SpringBootApplication(包含@ComponentScan),会导致 ClassInA 这个被实例化。虽然B项目里是排除ClassInA的实例化的,但是A项目却实例化了ClassInA。最终结果就是B项目的排除没有生效。

这里涉及到两个@ComponentScan(一个在B项目,另一个是A项目由@SpringBootApplication所引入的@ComponentScan),这两个是互相独立起作用的,一个禁止一个允许,最终导致实例化了

2、排除规则不生效怎么办

这个写法不生效 先clean再install

<excludes>
    <exclude>
        com/wyf/test/sub/AopFilterSpringinterceptorOrderingApplication.java
    </exclude>
</excludes>

参考文章:

springboot项目如何打包给其他项目引用_程序员超时空的博客-优快云博客_springboot项目引用其他项目
springboot打成可以被直接引用的Jar包_草上兔的博客-优快云博客_springboot 打可运行jar包
 

### Spring Boot 应用打包为 JAR 并在其他项目引用 #### 打包过程 为了将Spring Boot应用程序打包成JAR文件,在`pom.xml`文件内需加入特定的构建插件。具体来说,应包含如下所示的内容: ```xml <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> ``` 上述配置允许Maven处理项目的编译、测试以及最终创建一个可执行的JAR文件[^2]。 完成这些更改之后,可以通过命令行工具来触发实际的打包操作。对于基于Maven管理依赖关系的应用而言,只需简单地运行`mvn clean package`指令即可实现目标;而对于采用Gradle作为构建系统的场景,则可以利用`gradle build -x test`(其中`-x test`参数用于跳过单元测试阶段),从而得到位于`build/libs/`目录下的JAR文件[^4]。 #### 在其他项目引用此JAR 当希望在一个新的工程里重用已有的Spring Boot模块时,除了常规的方式外,还可以考虑将其转换成为本地仓库中的构件供后续调用。这通常涉及到两步工作:一是安装自定义库至本地存储位置;二是更新新项目的依赖声明以便识别外部资源。 ##### 安装JAR到本地Maven仓库 如果原始的Spring Boot应用是以Maven方式进行管理和构建的话,那么可以直接借助于`install:install-file`目标把生成好的JAR放置入个人计算机上的中央缓存区。相应的CLI语句形式如下: ```bash mvn install:install-file \ -Dfile=/path/to/my-springboot-app.jar \ -DgroupId=com.example \ -DartifactId=my-springboot-app \ -Dversion=0.0.1-SNAPSHOT \ -Dpackaging=jar ``` 此处需要注意替换掉路径和元数据部分以匹配实际情况。 ##### 更新POM或Build Script 一旦完成了上面提到的操作步骤,下一步就是在打算集成该组件的新项目里面调整其对应的构建脚本——无论是`pom.xml`(针对Maven)还是`build.gradle`(面向Gradle),都应当增加一条指向刚才所安置下来的制品项的新条目。例如,在Maven环境下可能是这样的样子: ```xml <dependency> <groupId>com.example</groupId> <artifactId>my-springboot-app</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency> ``` 而如果是Gradle用户,则可以在dependencies闭包内部添加相似的一行代码: ```groovy implementation 'com.example:my-springboot-app:0.0.1-SNAPSHOT' ``` 另外一种方法是直接复制生成的JAR文件到目标项目的`lib`文件夹下,并相应地修改IDE设置让其认识到这个额外的位置。不过这种方法不够优雅也不利于长期维护,因此不推荐广泛采纳。 最后值得注意的是,为了让被引入方能够正常加载来自第三方源码里的Bean实例和其他上下文信息,可能还需要确保启动类上有恰当的基础包扫描范围设定,比如这样: ```java @SpringBootApplication(scanBasePackages = {"com.example", "com.external"}) public class Application { } ``` 这里的`scanBasePackages`属性指定了哪些根级命名空间下的对象会被自动探测并注册给IoC容器使用[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值