SpringBoot打jar包,引入自定义的jar包和配置文件

该博客介绍了如何在Maven配置中设置spring-boot-maven-plugin插件,包括包含系统范围的依赖和排除特定jar(如lombok)。同时,展示了如何将特定资源目录的配置文件打包到指定路径,并跳过测试阶段进行打包。此外,还展示了如何引用并打包本地自定义jar文件。

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

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <!--代表maven打包时会将外部引入的jar包-->
                    <includeSystemScope>true</includeSystemScope>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>

        <resources>
            <resource>
                <!-- 将classpath下自定义的配置文件打入jar包 -->
                <directory>src/main/resources/conf</directory>
                <targetPath>/conf/</targetPath>
                <includes>
                    <include>**/*.txt</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

 pom.xml中引入自定义jar

 <dependency>
            <groupId>com.wenge</groupId>
            <artifactId>KeywordsExtract</artifactId>
            <scope>system</scope>
            <version>0.1</version>
            <systemPath>${project.basedir}/src/main/resources/jar/KeywordsExtract_1.3.jar</systemPath>
        </dependency>

maven打包时跳过Test

<properties>
        <java.version>1.8</java.version>
        <skipTests>true</skipTests>
    </properties>

项目结构:

 

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

余额充值