有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

JAVAlang.IllegalState异常LifeCycleCProcessor和ApplicationEventMulticaster在使用Spring引导时未初始化

我创建了一个spring引导包装器类,如下所示:

package package.for;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;

@ComponentScan
@EnableAutoConfiguration
public class AppBooter {

    public static void main(String args[]){
        SpringApplication.run("path/to/context.xml", args);
        System.out.println("============ done");
        do{

        }while(true);
    }
}

上下文。xml包含指向主类的bean,如下所示:

<bean id="starter" class="package.for.AppBooter" />

以及我需要的其他几种咖啡豆

关于依赖关系,我有以下几点:

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

    <dependency>
        <groupId>axis</groupId>
        <artifactId>axis</artifactId>
        <version>1.4</version>
        <scope>provided</scope>
        <exclusions>
            <exclusion>
                <groupId>commons-logging</groupId>
                <artifactId>commons-logging</artifactId>
            </exclusion>
            <exclusion>
                <groupId>axis</groupId>
                <artifactId>axis-wsdl4j</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId> wsdl4j</groupId>
        <artifactId>wsdl4j</artifactId>
        <version>1.6.2</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>jcl-over-slf4j</artifactId>
        <version>1.7.7</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <version>3.1.0</version
    </dependency>
    <dependency>
        <groupId>javax.servlet.jsp</groupId>
        <artifactId>javax.servlet.jsp-api</artifactId>
        <version>2.3.1</version>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-web</artifactId>
        <version>4.1.1.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.1.1.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>opensymphony</groupId>
        <artifactId>sitemesh</artifactId>
        <version>2.5</version>
    </dependency>

但是,当我运行时,会出现以下异常:

Exception in thread "main" 2014-10-07 16:12:54.267  INFO 4616 --- [       Thread-1] ationConfigEmbeddedWebApplicationContext : Closing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@6c4cbf96: startup date [Tue Oct 07 16:12:50 CEST 2014]; root of context hierarchy
java.lang.NoSuchMethodError: org.springframework.data.repository.config.RepositoryConfigurationDelegate.<init>(Lorg/springframework/data/repository/config/RepositoryConfigurationSource;Lorg/springframework/core/io/ResourceLoader;Lorg/springframework/core/env/Environment;)V
    at org.springframework.boot.autoconfigure.data.AbstractRepositoryConfigurationSourceSupport.registerBeanDefinitions(AbstractRepositoryConfigurationSourceSupport.java:58)
    at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitionsFromRegistrars(ConfigurationClassBeanDefinitionReader.java:319)
    at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitionsForConfigurationClass(ConfigurationClassBeanDefinitionReader.java:139)
    at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitions(ConfigurationClassBeanDefinitionReader.java:116)
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.processConfigBeanDefinitions(ConfigurationClassPostProcessor.java:324)
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanDefinitionRegistry(ConfigurationClassPostProcessor.java:243)
    at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanDefinitionRegistryPostProcessors(PostProcessorRegistrationDelegate.java:254)
    at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:94)
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:608)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:463)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:109)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:691)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:320)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:952)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:941)
    at package.for.AppBooter.main(AppBooter.java:12)
2014-10-07 16:12:54.303  WARN 4616 --- [       Thread-1] ationConfigEmbeddedWebApplicationContext : Exception thrown from ApplicationListener handling ContextClosedEvent

java.lang.IllegalStateException: ApplicationEventMulticaster not initialized - call 'refresh' before multicasting events via the context: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@6c4cbf96: startup date [Tue Oct 07 16:12:50 CEST 2014]; root of context hierarchy
    at org.springframework.context.support.AbstractApplicationContext.getApplicationEventMulticaster(AbstractApplicationContext.java:345)
    at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:332)
    at org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:879)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.doClose(EmbeddedWebApplicationContext.java:141)
    at org.springframework.context.support.AbstractApplicationContext$1.run(AbstractApplicationContext.java:808)

2014-10-07 16:12:54.304  WARN 4616 --- [       Thread-1] ationConfigEmbeddedWebApplicationContext : Exception thrown from LifecycleProcessor on context close

java.lang.IllegalStateException: LifecycleProcessor not initialized - call 'refresh' before invoking lifecycle methods via the context: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@6c4cbf96: startup date [Tue Oct 07 16:12:50 CEST 2014]; root of context hierarchy
    at org.springframework.context.support.AbstractApplicationContext.getLifecycleProcessor(AbstractApplicationContext.java:358)
    at org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:887)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.doClose(EmbeddedWebApplicationContext.java:141)
    at org.springframework.context.support.AbstractApplicationContext$1.run(AbstractApplicationContext.java:808)

至于我是如何包装jar的,这里是插件片段:

       <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <mainClass>package.for.AppBooter</mainClass>
            </configuration>
            <version>1.1.5.RELEASE</version>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                </execution>
            </executions
        </plugin>

共 (4) 个答案

  1. # 1 楼答案

    我认为问题的根本原因是:

    java.lang.NoSuchMethodError: org.springframework.data.repository.config.RepositoryConfigurationDelegate.<init>(Lorg/springframework/data/repository/config/RepositoryConfigurationSource;Lorg/springframework/core/io/ResourceLoader;Lorg/springframework/core/env/Environment;)V
        at org.springframework.boot.autoconfigure.data.AbstractRepositoryConfigurationSourceSupport.registerBeanDefinitions(AbstractRepositoryConfigurationSourceSupport.java:58)
    

    您尚未发布Spring数据依赖项的任何详细信息,但看起来您正在尝试使用一个与您正在使用的Spring Boot版本不兼容的Spring数据项目的版本。Spring Boot为整个Spring数据发布系列提供依赖关系管理,因此您最好的选择可能是从pom中的任何Spring数据依赖关系中删除该版本,并让Spring Boot的依赖关系管理控制该版本

  2. # 2 楼答案

    我面临着这个错误,我已经有了4.3.2。SpringWeb和SpringWebMVC的发行版

    解决了这个问题,这是因为定义了spring数据释放序列。解决了这个问题

  3. # 3 楼答案

    通过将SpringWeb和SpringWebMVC依赖项升级到4.0.7解决了这个问题。释放

  4. # 4 楼答案

    具有相同的问题,并且与依赖项无关

    我有以下代码:

    @Configuration
    public class ConfigurationClass {
        private final MyProperties MY_PROPERTIES;
    
        ConfigurationClass(MyProperties myProperties) {
            this.MY_PROPERTIES = myProperties
        }
    
        @Bean
        @LoadBalanced
        public RestTemplate testRestTemplate(RestTemplateBuilder builder) {
            return builder.setConnectTimeout(MY_PROPERTIES.getTimeout()).build();
        }
    }
    

    将其更改为以下选项可使其正常工作:

    @Configuration
    public class ConfigurationClass {
    
        @Bean
        @LoadBalanced
        public RestTemplate testRestTemplate(RestTemplateBuilder builder,
                                             MyProperties myProperties) {
            return builder.setConnectTimeout(myProperties.getTimeout()).build();
        }
    }
    

    但我不确定这为什么会引起问题。当您想在bean中使用构造函数注入时,可能无法使用它。希望有人能在评论中回答