SpringBoot引入第三方jar包或本地jar包的处理方式

简介: SpringBoot引入第三方jar包或本地jar包的处理方式

在项目开发中不可避免会遇到引入第三方jar包的情况,这些第三方jar是在Maven仓库中没有的。

有两种处理方式:

  • 将jar包安装在本地maven库(本地私服)
  • 将jar包放入项目目录中。

这里主要讲述第二种方式,而第二种方式又分两种情况:项目打jar包和项目打war包。

① 项目打jar包时引入第三方jar

项目打jar包此时是没有src/main/webap/WEB-INF/lib这样的路径的。

  • 在src/main/resources建立目录lib,然后将第三方jar包扔进去;
  • pom文件添加第三方jar依赖
  <!--引入第三方jar-Mas jar-->
    <dependency>
      <groupId>com.mas</groupId>
      <artifactId>mas-sdk</artifactId>
      <version>1.0-SNAPSHOT</version>
      <scope>system</scope>
      <systemPath>${project.basedir}/src/main/resources/lib/masmgc.sdk-0.0.1-SNAPSHOT.jar</systemPath>
    </dependency>

groupId,artifactId,version可随便写 。

  • pom文件中添加插件
<plugin>
  <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-maven-plugin</artifactId>
   <configuration>
       <includeSystemScope>true</includeSystemScope>
   </configuration>
</plugin>

打包后jar包的路径即在BOOT-INF\lib目录下。


② 项目打war包时引入第三方jar

项目打war包时就可以建立src/main/webap/WEB-INF/lib这样的路径的。

  • 在src/main/webapp/WEB-INF/建立目录lib,然后将第三方jar包扔进去;
  • pom文件添加第三方jar依赖
<!--引入第三方jar-Mas jar-->
<dependency>
  <groupId>com.mas</groupId>
  <artifactId>mas-sdk</artifactId>
  <version>1.0-SNAPSHOT</version>
  <scope>system</scope>
  <systemPath>${project.basedir}/src/main/webapp/WEB-INF/lib/masmgc.sdk-0.0.1-SNAPSHOT.jar</systemPath>
</dependency>

groupId,artifactId,version可随便写 。

  • pom文件中添加插件
<plugin>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-maven-plugin</artifactId>
</plugin>

打包后jar包的路径即在WEB-INF/lib目录下。


③ 项目打war包时引入第三方jar

与②不同的是,这里还可以把第三方jar仍旧放在src/main/resources/lib下面。

  • 在src/main/resources建立目录lib,然后将第三方jar包扔进去;
  • pom文件添加第三方jar依赖
  <!--引入第三方jar-Mas jar-->
    <dependency>
      <groupId>com.mas</groupId>
      <artifactId>mas-sdk</artifactId>
      <version>1.0-SNAPSHOT</version>
      <scope>system</scope>
      <systemPath>${project.basedir}/src/main/resources/lib/masmgc.sdk-0.0.1-SNAPSHOT.jar</systemPath>
    </dependency>

groupId,artifactId,version可随便写 。

  • pom文件中添加插件
<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-war-plugin</artifactId>
  <configuration>
    <webResources>
      <resource>
        <directory>src/main/resources/lib</directory>
        <targetPath>WEB-INF/lib/</targetPath>
        <includes>
          <include>**/*.jar</include>
        </includes>
      </resource>
    </webResources>
  </configuration>
</plugin>

打包后jar包的路径即在WEB-INF/lib目录下,但是src/main/resources下也会有lib目录,不过不影响使用。如果部署在Tomcat下,打包后的目录中可以把/WEB-INF/classes中的lib删掉,只保留WEB-INF/lib。

至此即可解决SpringBoot引入第三方jar的问题,有兴趣的可以继续往下看看两种插件打包结构的不同。

以下的测试都是打war包,且第三方jar在WEB-INF/lib下。


④ 单独使用spring-boot-maven-plugin打包结构

上面提到了两个插件:

<plugin>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
#   ###
<plugin>
  <groupId>org.apache.maven.plugins</groupId>
  <artifactId>maven-war-plugin</artifactId>
</plugin>

第一个是SpringBoot中的maven插件,其依赖了诸多插件。第二个就是以前常见的maven 打war包插件。

单独使用spring-boot-maven-plugin打包结构如下:

其WEB-INF下结构:


⑤ 单独使用maven-war-plugin打包结构

其WEB-INF结构如下:


很清爽对不对。


⑥ 二者都存在时

即pom文件如下:

<plugins>
  <plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
  </plugin>
  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
      <source>${java.version}</source>
      <target>${java.version}</target>
    </configuration>
  </plugin>
  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-war-plugin</artifactId>
    <!--<configuration>-->
      <!--<webResources>-->
        <!--<resource>-->
          <!--<directory>src/main/resources/lib</directory>-->
          <!--<targetPath>WEB-INF/lib/</targetPath>-->
          <!--<includes>-->
            <!--<include>**/*.jar</include>-->
          <!--</includes>-->
        <!--</resource>-->
      <!--</webResources>-->
    <!--</configuration>-->
  </plugin>
</plugins>

打包后结构如下:


WEB-INF 结构如下:


与④是相同的结构。


⑦ 再来一波以前SSM时使用maven打包的插件

<plugins>
 <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-compiler-plugin</artifactId>
       <version>3.1</version>
       <configuration>
         <source>1.8</source>
         <target>1.8</target>
       </configuration>
     </plugin>
     <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-source-plugin</artifactId>  
       <version>2.4</version>  
       <configuration>
         <source>1.8</source>
         <target>1.8</target>
       </configuration>
     </plugin>
     <plugin>
       <groupId>org.apache.maven.plugins</groupId>
       <artifactId>maven-war-plugin</artifactId>
       <version>2.2</version>
       <configuration>
         <source>1.8</source>
         <target>1.8</target>
       </configuration>
     </plugin> 
     <plugin>
  <groupId>org.apache.tomcat.maven</groupId>
  <artifactId>tomcat7-maven-plugin</artifactId>
  <version>2.2</version>
  <configuration>
    <uriEncoding>UTF-8</uriEncoding>
    <port>8990</port>
    <path>/</path>
    <update>true</update>
  </configuration>
  <executions>
    <execution>
      <phase>package</phase>
      <goals>
        <goal>run</goal>
      </goals>
    </execution>
  </executions>
 </plugin>
</plugins>

以前SSM使用的是Tomcat7,如果使用SpringBoot的情况下,Tomcat7就会出让你感觉莫名其妙的错误。


如Caused by: java.lang.ClassNotFoundException: javax.el.ELManager。


添加如下依赖(或者直接使用Tomcat8.X):

<dependency>
    <groupId>javax.el</groupId>
    <artifactId>javax.el-api</artifactId>
    <version>3.0.0</version>
</dependency>

SpringBoot建议使用Tomcat8.X。



目录
相关文章
|
5月前
|
Java 应用服务中间件 Spring
为什么SpringBoot的 jar 可以直接运行?
SpringBoot的 jar 可以直接运行的原因
470 2
|
3月前
|
数据可视化 Java 应用服务中间件
springboot打war包,成功部署
这篇文章介绍了如何将Spring Boot项目打包成WAR文件,并成功部署到Tomcat服务器的详细步骤。
212 0
springboot打war包,成功部署
|
3月前
|
Java Windows
如何在windows上运行jar包/JAR文件 如何在cmd上运行 jar包 保姆级教程 超详细
本文提供了一个详细的教程,解释了如何在Windows操作系统的命令提示符(cmd)中运行JAR文件。
1305 1
|
3月前
|
Java 数据库连接 mybatis
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码
该文档详细介绍了如何在Springboot Web项目中整合Mybatis,包括添加依赖、使用`@MapperScan`注解配置包扫描路径等步骤。若未使用`@MapperScan`,系统会自动扫描加了`@Mapper`注解的接口;若使用了`@MapperScan`,则按指定路径扫描。文档还深入分析了相关源码,解释了不同情况下的扫描逻辑与优先级,帮助理解Mybatis在Springboot项目中的自动配置机制。
189 0
Springboot整合Mybatis,MybatisPlus源码分析,自动装配实现包扫描源码
|
5月前
|
Java Maven 容器
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
使用IntelliJ IDEA的Artifacts功能,可以将项目依赖的第三方jar包打包进jar文件中,实现双击jar包即可直接运行。
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
|
5月前
|
Java Maven
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
这篇文章详细介绍了构建SpringBoot项目的过程,包括新建工程、选择环境配置、添加依赖、项目结构说明,并演示了如何编写一个简单的Controller控制器实现输出功能,最后讲解了如何使用Maven将项目打包成可执行的JAR包,并提供了运行JAR包的命令和测试效果。
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
|
5月前
|
Java Maven C++
【Azure Developer】记录一次使用Java Azure Key Vault Secret示例代码生成的Jar包,单独运行出现 no main manifest attribute, in target/demo-1.0-SNAPSHOT.jar 错误消息
【Azure Developer】记录一次使用Java Azure Key Vault Secret示例代码生成的Jar包,单独运行出现 no main manifest attribute, in target/demo-1.0-SNAPSHOT.jar 错误消息
|
5月前
|
前端开发 JavaScript Java
【Azure 应用服务】App Service For Windows 中如何设置代理实现前端静态文件和后端Java Spring Boot Jar包
【Azure 应用服务】App Service For Windows 中如何设置代理实现前端静态文件和后端Java Spring Boot Jar包
|
Java
SpringBoot:Jar包工程启动、停止、重启脚本
SpringBoot:Jar包工程启动、停止、重启脚本
1194 0
|
3月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
199 1

热门文章

最新文章