SpringBoot解决第三方依赖jar包(即Maven仓库上没有的jar包,只能找其它资源下载)的问题

转载自:https://www.cnblogs.com/xiaosiyuan/p/6894766.html

注意:这里所说的第三方jar包,是指Maven仓库上没有的jar包,只能找其它资源下载引入的。

公司现在用的是springboot+maven,想要把一些老的项目都改成这种框架。但是一些老的项目中有好多第三方的jar包或者是自己的jar包,maven库上没有。最初的解决方案是一个个的deploy到maven库上,但是遇到太多的三方jar包就太费事了。网上查了一下发现maven有一种方式可以将本地的Jar包依赖到项目中而不需要先deploy到maven库上。具体做法如下:

跟普通的java项目一样,新建个lib目录放jar包,我建在了src下。

pom文件中依赖这样写:

<!--添加外部依赖-->
    <dependency>
      <groupId>Ice</groupId>
      <artifactId>Ice</artifactId>
      <version>1.0</version>
      <scope>system</scope>
      <systemPath>${basedir}/src/lib/Ice.jar</systemPath>
    </dependency>

basedir是自带变量,指的是当前项目的绝对路径,三围自己随便写。

通过这种方式引入依赖后,在编码的时候没有问题,但是用mvn clean package打成jar包后运行就是报错,正式找不到这些jar包中的相关类。把jar包解压后在BOOT-INF/lib里面也确实没有发现用上述方式引入的jar包,看来是没有把src/lib目录里面的jar打进去,后来通过查找也终于找到方法了,修改pom文件,在build标签下增加如下配置

   <resources>
      <resource>
        <directory>src/lib</directory>
        <targetPath>BOOT-INF/lib/</targetPath>
        <includes>
          <include>**/*.jar</include>
        </includes>
      </resource>
      <resource>
        <directory>src/main/resources</directory>
        <targetPath>BOOT-INF/classes/</targetPath>
      </resource>
    </resources>

目的就是把src/lib下的jar打到BOOT-INF/lib下,但是必须要增加第二个resource,不然src/main/resources下的配置文件又打不进jar包了。

如果要打成war包,则pom文件需要这样改:

      <!--设置maven-war-plugins插件,否则外部依赖无法打进war包-->
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-war-plugin</artifactId>
        <configuration>
          <webResources>
            <resource>
              <directory>lib</directory>
              <targetPath>WEB-INF/lib/</targetPath>
              <includes>
                <include>**/*.jar</include>
              </includes>
            </resource>
          </webResources>
        </configuration>
      </plugin>

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在非maven项目中,使用第三方依赖jar是一种常见的做法。但是对于这种情况,将项目打jar可能会遇到一些问题。 首先,需要将项目中使用的第三方依赖jar添加到项目的类路径中。可以将这些jar放置在项目的lib目录下,并通过设置类路径来引用这些依赖。 接下来,需要创建一个可执行的jar。在非maven项目中,可以通过手动创建一个MANIFEST.MF文件,并在其中指定项目的入口类。同时,需要指定依赖jar在MANIFEST.MF文件中的路径。 然后,将项目的所有文件和依赖jar一起打成一个jar文件。可以使用命令行工具,如jar命令来完成该操作。在命令行中运行以下命令: jar -cvfm output.jar MANIFEST.MF -C project_dir . 其中,output.jar是要生成的jar的名称,MANIFEST.MF是上一步创建的文件,project_dir是项目的根目录。 最后,将生成的jar复制到其他地方进行测试或部署。 需要注意的是,这种方法生成的jar可能会比较复杂,因为它含了所有的依赖。如果想要生成一个更精简的jar,可以使用其他工具,如ProGuard来进行混淆和优化。 总结起来,即使在非maven项目中使用第三方依赖jar,也可以通过手动设置类路径和创建一个合适的MANIFEST.MF文件来打项目。这样可以方便地将项目的所有文件和依赖成一个可执行的jar

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值