【问题标题】:Unable to open nested jar file (spring-boot-starter-web) when running from jar从 jar 运行时无法打开嵌套的 jar 文件(spring-boot-starter-web)
【发布时间】:2016-03-31 19:55:00
【问题描述】:

我有一个 Spring Boot 应用程序,它通过 IntelliJ 的 Spring Boot 运行配置以及 mvn spring-boot:run 运行良好,但是,当我尝试通过 mvn package 打包时,从 java -jar application.jar 运行时出现以下错误

java.io.IOException: 无法打开嵌套的 jar 文件 'lib/spring-boot-starter-web-1.3.3.RELEASE.jar' 在 org.springframework.boot.loader.jar.JarFile.getNestedJarFile(JarFile.java:349) 在 org.springframework.boot.loader.archive.JarFileArchive.getNestedArchive(JarFileArchive.java:112) 在 org.springframework.boot.loader.archive.JarFileArchive.getNestedArchives(JarFileArchive.java:96) 在 org.springframework.boot.loader.ExecutableArchiveLauncher.getClassPathArchives(ExecutableArchiveLauncher.java:75) 在 org.springframework.boot.loader.Launcher.launch(Launcher.java:60) 在 org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:52)

原因:java.io.IOException: Unable to find ZIP central directory 读取 2227 字节后的记录 在 org.springframework.boot.loader.jar.CentralDirectoryEndRecord.(CentralDirectoryEndRecord.java:64) 在 org.springframework.boot.loader.jar.JarFile.(JarFile.java:118) 在 org.springframework.boot.loader.jar.JarFile.createJarFileFromFileEntry(JarFile.java:387) 在 org.springframework.boot.loader.jar.JarFile.createJarFileFromEntry(JarFile.java:357) 在 org.springframework.boot.loader.jar.JarFile.getNestedJarFile(JarFile.java:343) ... 5 更多

似乎类似于java.io.IOException when running Spring Boot jar on Centos 6.4 / Open JDK 1.7.0,但解决方案是删除与 TLD 库相关的损坏 jar 文件,并且该问题没有引用无法加载的嵌套 jar(所以我我不确定这是否是完全相同的问题)。我尝试删除并重新创建~/.m2/repository 目录无济于事。我也尝试过不同版本的 Spring Boot(因为我以前从未遇到过这个问题)但没有运气。

我的 pom 文件在下面。

<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.oranization</groupId>
    <artifactId>application</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!--Spring-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.3.3.RELEASE</version>
    </parent>
    <properties>
        <slf4j.version>1.7.12</slf4j.version>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.security.oauth</groupId>
            <artifactId>spring-security-oauth2</artifactId>
            <version>2.0.8.RELEASE</version>
        </dependency>
        <!--Spring-->

        <!--Logging-->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>log4j-over-slf4j</artifactId>
            <version>${slf4j.version}</version>
        </dependency>

        <!--Logging-->

        <!--Database-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.35</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time-hibernate</artifactId>
            <version>1.4</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.jadira.usertype</groupId>
            <artifactId>usertype.core</artifactId>
            <version>3.2.0.GA</version>
        </dependency>
        <dependency>
            <groupId>com.jolbox</groupId>
            <artifactId>bonecp-spring</artifactId>
            <version>0.8.0.RELEASE</version>
        </dependency>

        <!--Database-->

        <!--Joda Time-->
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.8.1</version>
        </dependency>
        <!--Joda Time-->

        <!--Test-->
        <dependency>
            <groupId>org.mockito</groupId>
            <artifactId>mockito-core</artifactId>
            <version>2.0.14-beta</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.hsqldb</groupId>
            <artifactId>hsqldb</artifactId>
            <version>2.3.2</version>
            <scope>test</scope>
        </dependency>

        <!--Test-->
        <!--Web Support-->
        <dependency>
            <groupId>org.tuckey</groupId>
            <artifactId>urlrewritefilter</artifactId>
            <version>4.0.3</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.datatype</groupId>
            <artifactId>jackson-datatype-joda</artifactId>
            <version>2.4.6</version>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.6.0</version>
        </dependency>
        <!--Web Support-->

        <!--Utils-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.4</version>
        </dependency>
        <dependency>
            <groupId>commons-beanutils</groupId>
            <artifactId>commons-beanutils</artifactId>
            <version>1.9.2</version>
        </dependency>
        <dependency>
            <groupId>xml-apis</groupId>
            <artifactId>xml-apis</artifactId>
            <version>1.4.01</version>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>com.google.maps</groupId>
            <artifactId>google-maps-services</artifactId>
            <version>0.1.7</version>
        </dependency>
        <dependency>
            <groupId>de.danielbechler</groupId>
            <artifactId>java-object-diff</artifactId>
            <version>0.93.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-csv</artifactId>
            <version>1.2</version>
        </dependency>
        <!--Utils-->

        <!--Reactor-->
        <dependency>
            <groupId>io.projectreactor</groupId>
            <artifactId>reactor-bus</artifactId>
            <version>2.0.7.RELEASE</version>
        </dependency>
        <!--Reactor-->

        <!--Swagger-->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.3.0</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.3.0</version>
        </dependency>
        <!--Swagger-->

        <!--Elasticsearch-->
        <dependency>
            <groupId>org.elasticsearch</groupId>
            <artifactId>elasticsearch</artifactId>
            <version>2.1.1</version>
        </dependency>

        <!-- AWS -->
        <dependency>
            <groupId>com.amazonaws</groupId>
            <artifactId>aws-java-sdk</artifactId>
            <version>1.9.33</version>
        </dependency>

        <!--PDF processing-->
        <dependency>
            <groupId>org.apache.pdfbox</groupId>
            <artifactId>pdfbox</artifactId>
            <version>1.8.11</version>
        </dependency>
        <!--PDF processing-->
        <!--Doc/Docx file processing-->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.13</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.13</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-scratchpad</artifactId>
            <version>3.13</version>
        </dependency>
        <!--Doc/Docx file processing-->

        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity</artifactId>
            <version>1.7</version>
        </dependency>

    </dependencies>

    <build>
        <finalName>application</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                </configuration>
            </plugin>

            <!-- Copy Dockerfile -->
            <plugin>
                <artifactId>maven-resources-plugin</artifactId>
                <executions>
                    <execution>
                        <id>copy-resources</id>
                        <phase>validate</phase>
                        <goals>
                            <goal>copy-resources</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${basedir}/target/
                            </outputDirectory>
                            <resources>
                                <resource>
                                    <directory>src/main/docker</directory>
                                    <filtering>true</filtering>
                                </resource>
                            </resources>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-antrun-plugin</artifactId>
                <version>1.8</version>
                <executions>
                    <execution>
                        <id>zip-files</id>
                        <phase>package</phase>
                        <goals>
                            <goal>run</goal>
                        </goals>
                        <configuration>
                            <target>
                                <zip destfile="${basedir}/target/app.zip"
                                     basedir="${basedir}/target"
                                     includes="Dockerfile, Dockerrun.aws.json, application.jar"/>
                            </target>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

编辑 在 Finder 中删除 ~/m2/repository 目录并清空垃圾箱后,我从 Intellij 进行了重新导入,然后从 Maven 项目菜单中进行了 package。当尝试使用 java -jar target/application.jar 运行最终产品时,我收到一个新错误:

线程“主”java.lang.IllegalStateException 中的异常: java.io.IOException:无法读取字节 在 org.springframework.boot.loader.ExecutableArchiveLauncher.(ExecutableArchiveLauncher.java:53) 在 org.springframework.boot.loader.ExecutableArchiveLauncher.(ExecutableArchiveLauncher.java:45) 在 org.springframework.boot.loader.JarLauncher.(JarLauncher.java:34) 在 org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:52) 引起:java.io.IOException:无法读取字节 在 org.springframework.boot.loader.jar.Bytes.get(Bytes.java:53) 在 org.springframework.boot.loader.jar.JarEntryData.(JarEntryData.java:70) 在 org.springframework.boot.loader.jar.JarEntryData.fromInputStream(JarEntryData.java:212) 在 org.springframework.boot.loader.jar.JarFile.loadJarEntries(JarFile.java:155) 在 org.springframework.boot.loader.jar.JarFile.(JarFile.java:122) 在 org.springframework.boot.loader.jar.JarFile.(JarFile.java:104) 在 org.springframework.boot.loader.jar.JarFile.(JarFile.java:95) 在 org.springframework.boot.loader.archive.JarFileArchive.(JarFileArchive.java:65) 在 org.springframework.boot.loader.archive.JarFileArchive.(JarFileArchive.java:61) 在 org.springframework.boot.loader.Launcher.createArchive(Launcher.java:152) 在 org.springframework.boot.loader.ExecutableArchiveLauncher.(ExecutableArchiveLauncher.java:50) ... 3 更多

【问题讨论】:

  • 我猜你的 PATH 中有 java jdk7。检查java版本java -v,看看是Java 1.7还是1.8。
  • 它是 Java 8:java version "1.8.0_25" Java(TM) SE Runtime Environment (build 1.8.0_25-b17) Java HotSpot(TM) 64-Bit Server VM (build 25.25-b02, mixed mode)
  • 这看起来确实像 Centos 上的 Spring Boot jar...问题。您是否尝试过清理 maven 本地 repo,重建索引,然后清理项目 n 然后打包?
  • @SanjayRawat 我尝试删除 ~/.m2/repository 目录。我应该尝试其他步骤吗?
  • 我不确定 intelliJ,但对于 Eclipse,您应该尝试在 Maven 的本地存储库上重建索引。然后mvn cleanmvn package。在 IntelliJ 中有一个名为 Reimport All maven Project 的选项,然后当然是 mvn cleanmvn package

标签: spring maven spring-boot


【解决方案1】:

原来这与this question 有关。尽管 Java 8 据称支持大量文件,但我的 jar 文件中有大约 77k(由于我的 React 前端包含 node_modules 目录),当我正确配置排除过滤器时,它就像一个魅力。

故事的寓意,达到最大文件限制会导致奇怪的事情发生。

【讨论】:

  • Node_Modules 文件夹实际上包含数十亿个文件 xD。我想这是一个教训。
猜你喜欢
  • 1970-01-01
  • 2016-12-25
  • 2019-05-31
  • 2021-03-05
  • 2017-07-02
  • 2021-05-27
  • 2018-02-18
  • 2021-10-13
  • 2019-02-19
相关资源
最近更新 更多