Springboot项目(包含第三方jar包)打成jar包方法

Spring Boot项目通常以jar包形式部署,其jar包发布方法主要是修改pom.xml文件。具体步骤为:修改项目发布形式、配置加载第三方jar包的目录、指定第三方jar包的打包路径,最后执行mvn clean package命令生成jar包。

Spring Boot项目一般是以jar包形式部署,下面就着重介绍其jar包发布的方法,一般来说,该方法只需要修改pom.xml文件即可。以下是具体步骤:

1、修改项目发布形式

<packaging>jar</packaging>

2、配置加载第三方jar包的目录

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>${maven-compiler-plugin.version}</version>
    <configuration>
        <source>1.8</source>
        <target>1.8</target>
        <skip>true</skip>
        <encoding>UTF-8</encoding>
        <compilerArguments>
            <extdirs>${project.basedir}/src/main/resources/lib</extdirs>
        </compilerArguments>
    </configuration>
</plugin>

3、指定第三方jar包的打包路径

<!-- 主要配置:将引用的第三方 jar 包打进生成的 jar 文件的 BOOT-INF/lib 目录中 -->
<resources>
    <resource>
        <directory>src\main\resources\lib</directory>
        <targetPath>BOOT-INF\lib</targetPath>
      <!--  <includes>
            <include>**/*.jar</include>
        </includes>-->
    </resource>
    <resource>
        <directory>src/main/resources</directory>
    </resource>
</resources>

4、执行mvn clean package命令即可生成相应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]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值