2014-07-10 224 views
6

我嘗試設置基本SolrRepository應用程序,並有ApplicationContext的負載在此錯誤:java.lang.IllegalArgumentException異常:環境不能爲空

Caused by: java.lang.IllegalArgumentException: Environment must not be null! 
    at org.springframework.util.Assert.notNull(Assert.java:112) 
    at org.springframework.data.repository.config.RepositoryConfigurationSourceSupport.<init>(RepositoryConfigurationSourceSupport.java:50) 
    at org.springframework.data.repository.config.AnnotationRepositoryConfigurationSource.<init>(AnnotationRepositoryConfigurationSource.java:74) 
    at org.springframework.data.repository.config.RepositoryBeanDefinitionRegistrarSupport.registerBeanDefinitions(RepositoryBeanDefinitionRegistrarSupport.java:74) 
    at org.springframework.context.annotation.ConfigurationClassParser.processImport(ConfigurationClassParser.java:394) 
    at org.springframework.context.annotation.ConfigurationClassParser.doProcessConfigurationClass(ConfigurationClassParser.java:204) 
    at org.springframework.context.annotation.ConfigurationClassParser.processConfigurationClass(ConfigurationClassParser.java:163) 
    at org.springframework.context.annotation.ConfigurationClassParser.parse(ConfigurationClassParser.java:138) 
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.processConfigBeanDefinitions(ConfigurationClassPostProcessor.java:284) 
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanDefinitionRegistry(ConfigurationClassPostProcessor.java:225) 
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:630) 
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:461) 
    at org.springframework.test.context.support.AbstractGenericContextLoader.loadContext(AbstractGenericContextLoader.java:120) 
    at org.springframework.test.context.support.AbstractGenericContextLoader.loadContext(AbstractGenericContextLoader.java:60) 
    at org.springframework.test.context.support.AbstractDelegatingSmartContextLoader.delegateLoading(AbstractDelegatingSmartContextLoader.java:100) 
    at org.springframework.test.context.support.AbstractDelegatingSmartContextLoader.loadContext(AbstractDelegatingSmartContextLoader.java:248) 
    at org.springframework.test.context.CacheAwareContextLoaderDelegate.loadContextInternal(CacheAwareContextLoaderDelegate.java:64) 
    at org.springframework.test.context.CacheAwareContextLoaderDelegate.loadContext(CacheAwareContextLoaderDelegate.java:91) 
    ... 28 more 

這裏是我的ConfigClass:

@Configuration 
@PropertySource("classpath:sandbox.properties") 
@ComponentScan("sandbox.solr") 
@EnableSolrRepositories(basePackages = { "sandbox.solr.repository" }, multicoreSupport = true) 
public class StreamingSolrConf { 

    @Resource 
    private Environment env; 

    @Bean 
    public SolrServer solrServer() { 
     return new HttpSolrServer(env.getRequiredProperty("solr.server.url")); 
    } 

    @Bean 
    public SolrTemplate solrTemplate() { 
     return new SolrTemplate(solrServer()); 
    } 
} 

而且我的存儲庫接口:

package sandbox.solr.repository; 

import org.springframework.data.solr.repository.SolrCrudRepository; 

public interface SandboxRepository extends SolrCrudRepository<Document, String> { 
} 

無法確定爲什麼環境不在第正確的時間在春天的背景下。 我錯過了什麼? 此致敬禮。

+1

解決! 我正在使用spring-data-solr-1.2.1.RELEASE和spring-3.2.8.RELEASE 要麼 - 降級到spring-data-solr-1.1.3-RELEASE並保留spring-3.2.8 .RELEASE - 升級到spring-3.2.9.RELEASE以保持spring-data-solr-1.2.1.RELEASE 將解決問題! – xt0f

+0

請把它作爲anwser發佈。這幫了我很多,謝謝! – kboom

回答

3

正好解決了這個問題(見原題評論):

他用的是spring-data-solr-1.2.1.RELEASEspring-3.2.8.RELEASE無論是。 降級到spring-data-solr-1.1.3-RELEASE並留在spring-3.2.8.RELEASE或升級到spring-3.2.9.RELEASE以保持spring-data-solr-1.2.1.RELEASE將解決問題。

相關問題