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。



目录
相关文章
|
1月前
|
Java Windows
如何在windows上运行jar包/JAR文件 如何在cmd上运行 jar包 保姆级教程 超详细
本文提供了一个详细的教程,解释了如何在Windows操作系统的命令提示符(cmd)中运行JAR文件。
898 1
|
3月前
|
Java Maven 容器
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
使用IntelliJ IDEA的Artifacts功能,可以将项目依赖的第三方jar包打包进jar文件中,实现双击jar包即可直接运行。
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
|
3月前
|
Java Maven
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
这篇文章详细介绍了构建SpringBoot项目的过程,包括新建工程、选择环境配置、添加依赖、项目结构说明,并演示了如何编写一个简单的Controller控制器实现输出功能,最后讲解了如何使用Maven将项目打包成可执行的JAR包,并提供了运行JAR包的命令和测试效果。
构建Springboot项目、实现简单的输出功能、将项目打包成可以执行的JAR包(详细图解过程)
|
3月前
|
SQL 前端开发 Java
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
这篇文章介绍了如何在IntelliJ IDEA中使用Maven将Spring Boot项目打包成可运行的jar包,并提供了运行jar包的方法。同时,还讨论了如何解决jar包冲突问题,并提供了在IDEA中同时启动Vue前端项目和Spring Boot后端项目的步骤。
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
|
3月前
|
Java Docker 容器
SpringBoot Jar 包太大 瘦身 【终极版】
SpringBoot Jar 包太大 瘦身 【终极版】
257 1
|
3月前
|
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 错误消息
|
3月前
|
前端开发 JavaScript Java
【Azure 应用服务】App Service For Windows 中如何设置代理实现前端静态文件和后端Java Spring Boot Jar包
【Azure 应用服务】App Service For Windows 中如何设置代理实现前端静态文件和后端Java Spring Boot Jar包
|
3月前
|
Java
SpringBoot Jar 包太大 瘦身 【初试】
SpringBoot Jar 包太大 瘦身 【初试】
26 0
|
3月前
|
Java Maven Windows
Maven 引用jar包冲突 Intellij 查找排除JAR包的依赖关系(Maven Helper)
Maven 引用jar包冲突 Intellij 查找排除JAR包的依赖关系(Maven Helper)
53 0
|
4月前
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
465 2
[JarEditor]可直接修改jar包的IDEA插件

热门文章

最新文章

下一篇
无影云桌面