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。

猜你喜欢

转载自blog.csdn.net/J080624/article/details/81505937