2016-03-07 17 views
6

インタフェースをインスタンス化できません:ラン春ブートアプリケーションエラー:私は春のプロジェクトを持って、それが春のブートを使用して、次のembaddedのTomcatで動作するようにしようorg.springframework.context.ApplicationListener

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

この私はMavenのコマンドを使用している場合、私のアプリケーション

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

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

} 

です:mvn spring-boot:run、プロジェクトがうまく起動しますが、私は、デバッグに必要なので、私はInteliJで、このmainメソッドを実行し、例外が発生します。

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> 
+0

あなたがhttp://stackoverflow.com/questions/31489947/noclassdeffounderror-genericapplicationlistener-when-を確認しました動作しますが、同じエラーが発生しましたswitch-from-spring-bo –

答えて

8

は、これはどこかあなたの春の依存関係が、必ずしもそうではないだけで春ブーツと春自体にバージョン不一致の症状です。

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

と私の春クラウドコンフィグ依存性::私は私の春のブート親の間にこれを持っていた

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

何らかの理由で、私はせずに、ばねクラウド-config設定 - クライアントの依存関係を定義することはできませんよ明示的なバージョン宣言。

最新のリリースバージョン(1.3.5.RELEASEと1.1.1.RELEASE)の両方に更新すると、それが解決されました。

0

私はちょうど春のブート親のリリースバージョンを変更し、今ではすべてが右

+0

そうでなければ、詳細に説明する必要があります。 –

関連する問題