maven、springboot项目编译打包本地jar、第三方jar包

0. 引言

一般我们在maven项目中都是通过引入pom坐标的形式来引入第三方jar包,但某些场景下,第三方是直接提供的jar包文件,这就需要我们从本地引入第三方包并进行打包。所以我们今天来看下如何进行本地引入第三方包操作

1. 步骤

1、在项目下创建lib文件夹,或者其他文件夹,将第三方包放入该文件夹下
在这里插入图片描述

2、IDEA中执行快捷键F4,或手动进入Project Settings,在Libraries中点击添加jar包,选择我们刚刚引入的jar包
在这里插入图片描述

3、修改pom文件,指定第三方jar包文件,
这里注意要添加<includeSystemScope> true </includeSystemScope>配置,这样才会在打包时加载本地的jar,否则会出现本地运行没问题,但编译打包出来就会报错找不到类

同时注意把<mainClass>中的<skip>调整成false, 否则引入的包不会一起打包出来

<build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.8.1</version><configuration><source>1.8</source><target>1.8</target><encoding>UTF-8</encoding><!--配置本地jar包在项目的存放路径jar包--><compilerArguments><extdirs>${project.basedir}/src/main/webapp/WEB-INF/lib</extdirs></compilerArguments></configuration></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-war-plugin</artifactId><configuration><webResources><resource><!--配置本地jar包在项目中的存放路径-war包--><directory>src/main/webapp/WEB-INF/lib/</directory><!--配置打包时jar包的存放路径--><targetPath>WEB-INF/lib</targetPath><includes><include>**/*.jar</include></includes></resource></webResources></configuration></plugin><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>${spring-boot.version}</version><configuration><mainClass>com.example.security_demo.SecurityDemoApplication</mainClass><skip>false</skip><!-- 加入此配置,才会把本地的jar包也引进去 --><includeSystemScope> true </includeSystemScope></configuration><executions><execution><id>repackage</id><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build>

4、pom里添加刚刚引入的jar包,这里的systemPath路径就选择jar包所在的路径

 <dependency><groupId>com.cdp.product</groupId><artifactId>cdp-common-security</artifactId><version>11.0.0-SNAPSHOT</version><scope>system</scope><systemPath>${pom.basedir}/lib/cdp-common-security-java.jar</systemPath>
</dependency>

5、选择编译打包
在这里插入图片描述

6、查看打包出来的jar包,只要不是几十K的大小,这种10M+的,说明第三方包已经包含进去了
在这里插入图片描述

7、项目正常启动
在这里插入图片描述
8、调用测试接口也正常(这里test接口的作用是将入参做加密输出)
在这里插入图片描述

2. 总结

如上,我们就完成了本地引入第三方jar并实现编译打包的操作。如果你打包出来的文件运行有误,仔细检查下配置与我上述的是否一致

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/316372.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM是如何基于虚拟机栈运行的

众所周知&#xff1a;JVM执行Java代码是靠执行引擎实现的。执行引擎有两套解释器&#xff1a;字节码解释器、模板解释器。字节码解释器比较简单&#xff0c;不多说&#xff0c;看图。本篇文章咱们讨论模板解释器执行Java代码的底层原理。 早些年研究模板解释器看到R大用汇编写的…

你知道vue中key的原理吗?说说你对它的理解

一、Key是什么 开始之前&#xff0c;我们先还原两个实际工作场景 当我们在使用v-for时&#xff0c;需要给单元加上key <ul><li v-for"item in items" :key"item.id">...</li> </ul>用new Date()生成的时间戳作为key&#xff0c…

数据中心网络架构

参考&#xff1a; 一文读懂胖树 数据中心网络架构VL2详解 数据中心网络拓扑设计目标 总体目标 业务可以部署在任意的服务器上可以根据需要动态扩展或者缩小服务器规模 网络角度 均衡负载且高性能&#xff1a;服务器之间的性能仅受限于服务器网卡&#xff0c;而不是链路性能…

《Ensemble deep learning: A review》阅读笔记

论文标题 《Ensemble deep learning: A review》 集成深度学习&#xff1a; 综述 作者 M.A. Ganaie 和 Minghui Hu 来自印度理工学院印多尔分校数学系和南洋理工大学电气与电子工程学院 本文写的大而全。 初读 摘要 集成学习思想&#xff1a; 结合几个单独的模型以获得…

【GitHub】ssh: connect to host github.com port 22: Connection refused

本地使用git上传GitHub仓库时发现的一个报错&#xff0c;以为是本机连不上github了&#xff0c;ping过后发现能够正常访问&#xff0c;于是上网找到了一个很完美的解决方案 原因&#xff1a;22端口被占用或被防火墙屏蔽 解决方法&#xff1a;切换GitHub的443端口 1.首先找到…

【数据结构】手撕排序(排序的概念及意义、直接插入和希尔排序的实现及分析)

目录 一、排序的概念及其运用 1.1排序的概念 1.2排序运用 1.3 常见的排序算法 二、插入排序 2.1基本思想&#xff1a; 2.2直接插入排序&#xff1a; 2.3步骤&#xff1a; 2.4直接插入排序的实现 三、希尔排序( 缩小增量排序 ) 3.1希尔排序的发展历史 3.2 希尔…

跟着cherno手搓游戏引擎【2】:日志系统spdlog和premake的使用

配置&#xff1a; 日志库文件github&#xff1a; GitHub - gabime/spdlog: Fast C logging library. 新建vendor文件夹 将下载好的spdlog放入 配置YOTOEngine的附加包含目录&#xff1a; 配置Sandbox的附加包含目录&#xff1a; 包装spdlog&#xff1a; 在YOTO文件夹下创建…

研讨会分享 | 非遗文化的守正创新与数字化传播

12月17日&#xff0c;大势智慧受邀参与由南方科技大学创新创意设计学院&#xff08;以下简称“设计学院”&#xff09;举办的“非遗文化的守正创新与数字化传播”主题研讨会&#xff0c;与来自非遗、文化、设计、展陈、技术等领域的一众专家学者&#xff0c;共同探讨可持续视阈…

如何充值GPT会员账号?

详情点击链接&#xff1a;如何充值GPT会员账号&#xff1f; 一OpenAI 1.最新大模型GPT-4 Turbo 2.最新发布的高级数据分析&#xff0c;AI画图&#xff0c;图像识别&#xff0c;文档API 3.GPT Store 4.从0到1创建自己的GPT应用 5. 模型Gemini以及大模型Claude2二定制自己的…

nginx 一、安装与conf浅析

文章目录 一、安装nginxdocker方式安装linux方式安装Ubuntu 或 Debian 系统&#xff1a;CentOS 或 RHEL 系统&#xff1a; macOS 系统&#xff08;使用 Homebrew&#xff09;&#xff1a;Windows 系统&#xff1a; 二、nginx.conf浅析 一、安装nginx docker方式安装 docker s…

2024年Vue开发中的8个最佳工具

前言 Vue.js&#xff0c;一款当今非常流行的基于JavaScript的开源框架&#xff0c;旨在构建动态的可交互应用。 Vue.js以其直观的语法和灵活的架构而广受全球开发者的欢迎和赞誉。随着时间的推移&#xff0c;Vue不断进化&#xff0c;为开发者提供更多优秀的工具&#xff0c;以…