Springboot中引入本地jar包,并通过maven把项目打成可执行jar包

本文分享了在SpringBoot项目中整合本地依赖包的两种有效方法。一是通过在pom.xml中逐一添加本地依赖,二是利用maven-compiler-plugin插件,批量引入本地资源目录下的所有jar包,简化构建过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       最近把以往的老项目用SpringBoot进行了重构,老项目中有部分本地依赖包不是放在maven库里的,是本地开发直接引入,需要在mvn package的时候把本地依赖jar也打进可执行包中。

这种通用问题,在网上找了一圈却没发现什么好的解决办法,表示很惊讶。特此把解决办法记录共享下。

1.网上较多的推荐方法:在pom文件定义依赖来一一对应本地依赖的相关jar包

<dependency>
            <groupId>com.aliyun.alicom</groupId>
            <artifactId>alicom-mns-receive-sdk</artifactId>
            <version>0.0.1-SNAPSHOT</version>
            <scope>system</scope>
            <systemPath>${project.basedir}/src/main/resources/lib/alicom-mns-receive-sdk-1.0.0.jar</systemPath>
        </dependency>
        <dependency>
            <groupId>com.aliyun.mns</groupId>
            <artifactId>aliyun-sdk-mns</artifactId>
            <version>1.1.8</version>
            <scope>system</scope>
            <systemPath>${project.basedir}/src/main/resources/lib/aliyun-sdk-mns-1.1.8.jar</systemPath>
        </dependency>
</dependency>

参考文章:https://www.cnblogs.com/liukunjava/p/9577768.html

但是当本地jar包个数较多的时候,一个个的添加pom依赖,显得有点儿麻烦

2.添加maven插件(亲试可行)

 在resource目录下新建一个目录来存放本地依赖jar包

 

 

然后在pom文件中添加

maven-compiler-plugin

插件,并设置本地依赖文件的路径

<build>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.5.1</version>
        <inherited>true</inherited>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
          <encoding>UTF-8</encoding>
          <compilerArguments>
            <extdirs>src/main/resources/lib/cdh</extdirs>
          </compilerArguments>
        </configuration>
      </plugin>
    </plugins>
    <resources>
      <resource>
        <directory>src/main/resources/lib/cdh</directory>
        <targetPath>BOOT-INF/lib/</targetPath>
      </resource>
      <resource>
        <directory>src/main/resources</directory>
        <excludes>
          <exclude>**/*.jar</exclude>
        </excludes>
        <targetPath>BOOT-INF/classes/</targetPath>
      </resource>
      <resource>
        <directory>src/main/resources</directory>
        <excludes>
          <exclude>**/*.jar</exclude>
        </excludes>
        <targetPath>./</targetPath>
      </resource>
    </resources>
  </build>

 

这样当执行mvn package时就会引入设定目录下的所有本地依赖包,通过idea直接跑或者rebuild都是没问题的。

### 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、付费专栏及课程。

余额充值