SpringBoot 项目 添加外部依赖jar 包 并打包

本文介绍如何在Maven项目中配置本地jar包依赖,并确保这些依赖被打包进最终的应用程序中,适用于那些Maven无法直接下载的依赖。

有时在开发过程中需要某些依赖 ,这些依赖 maven 工具下载不成功 ,需要手动下载 jar包 添加到

工程中,在打包时也需要把 jar 包 一起 加入到工程 :

解决方案:

在 pom.xml 中加入如下红色标记 :表示依赖本地文件目录

<build>

<plugins>

<plugin>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-maven-plugin</artifactId>

<configuration>

<fork>true</fork> <!-- 如果没有该配置,devtools不会生效 -->

<includeSystemScope>true</includeSystemScope>

</configuration>

</plugin>

</plugins>

</build>

 

 

 

然后 加入 maven 依赖 (自定义的本地jar )和 maven 依赖的区别是加入了 红色标记

<dependency>

<groupId>net.sf.json-lib</groupId>

<artifactId>json-lib</artifactId>

<version>2.4</version>

<scope>system</scope>

<systemPath>${project.basedir}/lib/json-lib-2.4-jdk15.jar</systemPath>

</dependency>

 

 

 

注意: 如果目标 jar 有依赖其它jar 要把 其它jar包也要加入进来 ,否则在程序启动时会报错

最后使用 install 打包成功

### 打包含所有依赖JAR文件 对于非Spring Boot的Java Maven项目,可以通过配置`pom.xml`中的插件来实现将所有的依赖打包到一个可执行的JAR文件中。具体来说,可以利用Maven Assembly Plugin或Maven Shade Plugin完成这一目标。 #### 使用Maven Assembly Plugin 为了创建一个含了所有依赖的单一JAR文件,在项目的`pom.xml`内添加如下配置: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-assembly-plugin</artifactId> <version>3.3.0</version> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> <archive> <manifest> <mainClass>com.example.MainApp</mainClass> </manifest> </archive> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>single</goal> </goals> </execution> </executions> </plugin> </plugins> </build> ``` 上述XML片段定义了一个名为`maven-assembly-plugin`的插件实例化,指定了其版本号以及如何处理这个特定的任务。通过设置`descriptorRef`为`jar-with-dependencies`,指示该插件收集所有必要的库至最终产物之中[^1]。 #### 使用Maven Shade Plugin 另一种方法是采用Maven Shade Plugin来进行同样的操作。此方式同样需要编辑`pom.xml`文件加入相应的部分: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.2.4</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <!-- 添加清单条目 --> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>com.example.MainApp</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 这段代码展示了怎样运用`maven-shade-plugin`来达成相同的效果——即生成带有全部所需外部资源的一个独立运行体。值得注意的是这里也设定了启动应用程序所需的主类路径。 无论选用哪种方案,都需要确保替换掉示例中的`com.example.MainApp`为主应用的实际全限定名。之后只需正常执行`mvn clean package`命令即可得到预期的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值