天天看点

记一次Unable to open nested entry ‘BOOT-INFlib.jar‘. It has been compressed

2022年8月23日

问题背景

前段时间由于工作失误,误将工程项目中某一个依赖包没有添加@loadbalanced注解就直接打包依赖到的主工程中,并发送项目现场测试。出来混的,迟早都要还的。这不,今天就街道项目现场测试部同事投诉,说是程序包无法启动。报错如下:

记一次Unable to open nested entry ‘BOOT-INFlib.jar‘. It has been compressed

排查原因

​ 当时第一反应是bis-service这个包咋这么熟悉嗫,灵光一闪,WC,这不是我单独打包替到主工程包里面的那个依赖包么。那这个问题的排查思路也就出来了:

  • 将bis-service替换到程序包的lib时出错
  • bis-service包本身有错

    如果bis-service包本身含错,报错信息应该不是这样,所以问题产生的原因可以锁定在使用bis-service替换到程序包lib过程中。

问题产生原因分析

当时将bis-service替换到lib中时,主程序是已经打包成了jar,所以当时是直接以解压软件打开后,将bis-service.jar包替换致lib下,重新压缩。是否是压缩软件重新压缩过程中,将bis-service.jar也压缩了,所以导致springboot不能读取该包?

解决方案

既然不能直接使用解压软件,那就直接使用java自带命令解压后,然后将对应jar包替换到lib中,在使用java命令重新压缩不就行了么(我可真是个小天才)。

  1. 使用如下命令,将主程序包解压, 其中xxx是需要解压的jar包名
    jar -xvf xxx.jar
               
  2. 解压后,将需要替换的jar包替换到/BOOT-INF/lib/ 下,再使用如下命令重新压缩
    jar -cfM0 ./
               

结果

将替换好的主程序包java -jar,嘿,好了!

结果

将替换好的主程序包java -jar,嘿,好了!

记一次Unable to open nested entry ‘BOOT-INFlib.jar‘. It has been compressed