清单错误将 spring-boot 启动为 java 应用程序

Posted

技术标签:

【中文标题】清单错误将 spring-boot 启动为 java 应用程序【英文标题】:Manifest error lanching spring-boot as java application 【发布时间】:2018-02-07 00:00:06 【问题描述】:

我无法在我的 Eclipse 3.9.0RELEASE 中运行我的 Spring Boot 应用程序。 如果使用以下命令在 Prompt 上启动,它运行良好:

mvn spring-boot:run

但我更喜欢使用我的 Spring 客户端而不是命令提示符, 当我尝试运行它时,执行: Run As-> Java Application or Spring Boor App ,然后我收到此错误:

ERROR StatusLogger 找不到 log4j2 配置文件。使用默认配置:仅将错误记录到控制台。 线程“main”java.lang.IllegalStateException 中的异常:无法从 jar 文件的清单中读取 Class-Path 属性:/C:/Users/MyFirstName%20MySecondName/.m2/repository/org/codehaus/groovy/groovy/2.4。 7/groovy-2.4.7.jar 在 org.springframework.boot.devtools.restart.ChangeableUrls.getUrlsFromClassPathOfJarManifestIfPossible(ChangeableUrls.java:100) 在 org.springframework.boot.devtools.restart.ChangeableUrls.fromUrlClassLoader(ChangeableUrls.java:88) 在 org.springframework.boot.devtools.restart.DefaultRestartInitializer.getUrls(DefaultRestartInitializer.java:91) 在 org.springframework.boot.devtools.restart.DefaultRestartInitializer.getInitialUrls(DefaultRestartInitializer.java:54) 在 org.springframework.boot.devtools.restart.Restarter.(Restarter.java:134) 在 org.springframework.boot.devtools.restart.Restarter.initialize(Restarter.java:531) 在 org.springframework.boot.devtools.restart.RestartApplicationListener.onApplicationStartedEvent(RestartApplicationListener.java:64) 在 org.springframework.boot.devtools.restart.RestartApplicationListener.onApplicationEvent(RestartApplicationListener.java:46) 在 org.springframework.context.event.SimpleApplicationEventMulticaster.invokeListener(SimpleApplicationEventMulticaster.java:166) 在 org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:138) 在 org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:121) 在 org.springframework.boot.context.event.EventPublishingRunListener.publishEvent(EventPublishingRunListener.java:111) 在 org.springframework.boot.context.event.EventPublishingRunListener.started(EventPublishingRunListener.java:60) 在 org.springframework.boot.SpringApplicationRunListeners.started(SpringApplicationRunListeners.java:48) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:302) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:1185) 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:1174) 在 com.myshop.demo.Application.main(Application.java:26)

在我看来,IDE 无法成功创建 ma​​nifest.mf 文件(而 maven 插件却完美地完成了它),但我不知道如何解决这个问题。

我也尝试创建自己的文件粘贴在我的项目 pah 中:src/main/resources/META-INF/manifest.mf 在 jar 中找到的文件,使用 maven 插件创建。

ma​​nifest.mf:

Manifest-Version: 1.0
Implementation-Title: demo
Implementation-Version: 0.0.1-SNAPSHOT
Archiver-Version: Plexus Archiver
Built-By: MyFirstName MySecondName
Start-Class: com.myshop.demo.Application
Implementation-Vendor-Id: com.myshop
Spring-Boot-Version: 1.3.6.RELEASE
Created-By: Apache Maven
Build-Jdk: 1.8.0_121
Implementation-Vendor: Pivotal Software, Inc.
Main-Class: org.springframework.boot.loader.JarLauncher

但错误没有改变。 感谢您的帮助。

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<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.myshop</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.3.6.RELEASE</version>
</parent>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <!-- hot swapping, disable cache for template, enable live reload -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-rest</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
    </dependency>
    <!-- logging -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
        </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <compilerVersion>1.8</compilerVersion> 
                    <archive>
                        <manifest>
                            <mainClass>com.myshop.demo</mainClass>
                        </manifest>
                    </archive>     
            </configuration>
        </plugin>
    </plugins>
</build>

Application.java:

@SpringBootApplication
  public class Application     
   public static void main(String[] args) 

    SpringApplication.run(Application.class, args);
  

【问题讨论】:

向上........ 【参考方案1】:

这是一个 devtools 启动异常,请从 pom.xml 中删除该依赖项,然后重新运行应用程序。

【讨论】:

【参考方案2】:

groovy-2.4.7.jar 文件已损坏。

尝试手动从网上下载文件并复制到C:/Users/MyFirstName%20MySecondName/.m2/repository/org/codehaus/groovy/groovy/2.4.7/groovy-2.4.7.jar

它应该可以工作。

【讨论】:

以上是关于清单错误将 spring-boot 启动为 java 应用程序的主要内容,如果未能解决你的问题,请参考以下文章

spring boot 启动错误

使用 Angular 7 前端启动 Spring-Boot 应用程序时无法加载资源错误(缺少资源)

intellij idea 无法启动或调试 spring-boot

spring-boot:如果密码失败,则启动没有数据库的应用程序

spring-boot 项目启动过慢问题

spring-boot 战争在启动时失败