web-dev-qa-db-ja.com

スプリングブートアプリケーションエラーの実行:インターフェースorg.springframework.context.ApplicationListenerをインスタンス化できません

私は春のプロジェクトを持っていますが、春のブートを使用して、次の埋め込みTomcatで実行しようとします:

https://spring.io/guides/gs/rest-service/

これは私のアプリケーションです

//@Configuration
//@EnableAspectJAutoProxy
@SpringBootApplication
@ComponentScan(basePackages = "gux.prome")
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

}

Mavenコマンドを使用する場合:mvn spring-boot:run、プロジェクトは正常に開始されますが、デバッグする必要があるため、InteliJでこのメインメソッドを実行します。例外が発生します。

Exception in thread "main" Java.lang.IllegalArgumentException: Cannot instantiate interface org.springframework.context.ApplicationListener : org.springframework.boot.logging.ClasspathLoggingApplicationListener
    at org.springframework.boot.SpringApplication.createSpringFactoriesInstances(SpringApplication.Java:414)
    at org.springframework.boot.SpringApplication.getSpringFactoriesInstances(SpringApplication.Java:394)
    at org.springframework.boot.SpringApplication.getSpringFactoriesInstances(SpringApplication.Java:385)
    at org.springframework.boot.SpringApplication.initialize(SpringApplication.Java:263)
    at org.springframework.boot.SpringApplication.<init>(SpringApplication.Java:237)
    at org.springframework.boot.SpringApplication.run(SpringApplication.Java:1191)
    at org.springframework.boot.SpringApplication.run(SpringApplication.Java:1180)
    at gux.prome.config.Application.main(Application.Java:19)
    at Sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at Sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.Java:57)
    at Sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.Java:43)
    at Java.lang.reflect.Method.invoke(Method.Java:606)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.Java:134)
Caused by: Java.lang.NoClassDefFoundError: org/springframework/context/event/GenericApplicationListener
....

これはポンポンです:

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>gux</groupId>
  <artifactId>prome-data</artifactId>


  <version>1.0-SNAPSHOT</version>
  <name>prome-data Maven Webapp</name>
  <url>http://maven.Apache.org</url>

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

  <dependencies>

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- guava -->
    <dependency>
      <groupId>com.google.guava</groupId>
      <artifactId>guava</artifactId>
      <version>18.0</version>
    </dependency>
    <!-- end of guava -->


    <dependency>
      <groupId>joda-time</groupId>
      <artifactId>joda-time</artifactId>
      <version>2.9.2</version>
    </dependency>

  </dependencies>


  <properties>
    <Java.version>1.7</Java.version>
  </properties>


  <build>

    <finalName>prome-data</finalName>

    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>

      <!--<plugin>-->
      <!-- use Java 7 -->
        <!--<artifactId> maven-compiler-plugin</artifactId>-->
        <!--<version>3.1</version>-->
        <!--<configuration>-->
          <!--<source> 1.7</source>   -->
          <!--<target> 1.7</target>-->
        <!--</configuration>-->
      <!--</plugin>-->

    </plugins>
  </build>

  <!--<repositories>-->
    <!--<repository>-->
      <!--<id>spring-releases</id>-->
      <!--<url>http://repo.spring.io/libs-release</url>-->
    <!--</repository>-->
  <!--</repositories>-->

  <!--<pluginRepositories>-->
    <!--<pluginRepository>-->
      <!--<id>spring-releases</id>-->
      <!--<url>http://repo.spring.io/libs-release</url>-->
    <!--</pluginRepository>-->
  <!--</pluginRepositories>-->


</project>
13
Jaskey

これはバージョンの不一致の症状ですsomewhere Springの依存関係ですが、必ずしもSpring BootとSpring自体だけではありません。私はSpring Boot親の間にこれを持っていました:

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

と私のSpring Cloud Config依存関係:

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-config-client</artifactId>
  <version>1.0.4.RELEASE</version>
</dependency>

何らかの理由で、明示的なバージョン宣言なしにspring-cloud-config-client依存関係を定義することはできません。

両方を最新リリースバージョン(1.3.5.RELEASEおよび1.1.1.RELEASE)に更新することで解決しました。

結論
依存関係を最新のものに更新します

21
ISparkes

私は同じエラーがありました、私はちょうど春のブート親のリリースバージョンを変更し、今ではすべてが正常に動作します

0
petrucci