我想使用@Configuration批註來連接我的應用程序,但我一直在初始化程序之一中收到NullPointerException,因爲它引用的bean尚未初始化(我認爲)。我已經嘗試在web.xml中指定「root」配置類,並嘗試進行包掃描,但都沒有成功。如何確保依賴配置使用Spring @Configuration註釋初始化?
對不起,大代碼轉儲。 我試圖產生一個更簡單的類來重現問題,但當然,當我這樣做時,一切正常。這裏是我的課(進口消隱):
DataSourceConfig.java:
@Configuration
public class DataSourceConfig {
public DataSourceConfig() {
System.err.println("DataSourceConfig constructed...");
}
@Bean
public DataSource dataSource() {
BasicDataSource bean = new BasicDataSource();
bean.setDriverClassName("com.mysql.jdbc.Driver");
bean.setUrl("jdbc:mysql://localhost:3306/observation");
bean.setUsername("observation");
bean.setPassword("*******");
bean.setInitialSize(1);
bean.setMaxActive(5);
bean.setTestOnBorrow(true);
System.err.println("dataSource bean initialized: " + bean.toString());
return bean;
}
}
HibernateConfig.java
@Configuration
@Import(DataSourceConfig.class)
public class HibernateConfig {
public HibernateConfig() {
System.err.println("HibernateConfig constructing...");
}
@Autowired
private DataSourceConfig dataSourceConfig;
@Bean
protected NamingStrategy namingStrategy() {
return new ImprovedNamingStrategy();
}
private AnnotationSessionFactoryBean sessionFactoryBean = null;
@Bean
@DependsOn("dataSourceConfig")
public AnnotationSessionFactoryBean sessionFactory() {
if (sessionFactoryBean == null) {
sessionFactoryBean = new AnnotationSessionFactoryBean();
NPE Here--> sessionFactoryBean.setDataSource(dataSourceConfig.dataSource());
sessionFactoryBean.setSchemaUpdate(true);
sessionFactoryBean.setNamingStrategy(namingStrategy());
sessionFactoryBean.setPackagesToScan(new String[] {
"com.newco.observations.domain",
"com.newco.observations.domain.*" });
Properties props = new Properties();
props.setProperty("hibernate.default_schema", "observation");
props.setProperty("hibernate.dialect",
"org.hibernate.dialect.MySQLDialect");
props.setProperty("hibernate.show_sql", "true");
sessionFactoryBean.setHibernateProperties(props);
System.err.println("sessionFactory initialized");
}
return sessionFactoryBean;
}
@Bean
@DependsOn("dataSourceConfig")
public JdbcTemplate jdbcTemplate() {
return new JdbcTemplate(dataSourceConfig.dataSource());
}
@Bean
@DependsOn("sessionFactory")
public ResourceTransactionManager txManager() {
HibernateTransactionManager bean = new HibernateTransactionManager();
bean.setSessionFactory((SessionFactory) sessionFactory().getObject());
return bean;
}
@Bean
@DependsOn("sessionFactory")
public HibernateTemplate hibernateTemplate() {
return new HibernateTemplate((SessionFactory) sessionFactory()
.getObject());
}
}
DaoConfig.java:
@Configuration
@Import(HibernateConfig.class)
public class DaoConfig {
public DaoConfig()
{
System.err.println("DaoConfig constructing...");
}
private @Autowired HibernateConfig hibernateConfig;
@Bean
@DependsOn("hibernateTemplate")
public PhenomenonGroupDao phenomenonGroupDao()
{
PhenomenonGroupDaoImpl bean = new PhenomenonGroupDaoImpl();
bean.setHibernateTemplate(hibernateConfig.hibernateTemplate());
return bean;
}
@Bean
@DependsOn("hibernateTemplate")
public PhenomenonDao phenomenonDao()
{
PhenomenonDaoImpl bean = new PhenomenonDaoImpl();
bean.setHibernateTemplate(hibernateConfig.hibernateTemplate());
return bean;
}
@Bean
@DependsOn("hibernateTemplate")
public DiscretePhenomenonDao discretePhenomenonDao()
{
DiscretePhenomenonDaoImpl bean = new DiscretePhenomenonDaoImpl();
bean.setHibernateTemplate(hibernateConfig.hibernateTemplate());
return bean;
}
}
您可以看到System.err.println和@DependsOn註解是一種扯淡我正在做的帽子。
我可以提供完整的日誌,如果它是有用的,但這裏是我認爲是相關線(一點點的格式,以使其更具可讀性(也許)):
- 208 [線程0 ] INFO org.springframework.context.annotation.ConfigurationClassEnhancer
- 成功增強com.bjk.observation.server.config.DaoConfig;增強的類名稱爲:com.bjk.observation.server.config.DaoConfig $$ EnhancerByCGLIB $$ 96e1956
- 229 [線程0] INFO org.springframework.beans.factory.support.DefaultListableBeanFactory
- 預實例單身in org.s[email protected]185572a:定義bean [org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org。 springframework.context.annotation.internalCommonAnnotationProcessor,org.springframework.context.annotation.internalPersistenceAnnotationProcessor,daoConfig,com.bjk.observation.server.config.DataSourceConfig#0,dataSource,com.bjk.observation.server.config.HibernateConfig#0, namingS trategy,sessionFactory,jdbcTemplate,txManager,hibernateTemplate,現象GroupDao,現象Dao,discretePhenomenonDao];工廠層級DaoConfig的根構造...
- 252 [線程0] INFO org.springframework.beans.factory.support.DefaultListableBeanFactory
- 銷燬單身在org.s[email protected]185572a:定義bean [org.springframework.context.annotation.internalConfigurationAnnotationProcessor,org.springframework.context.annotation.internalAutowiredAnnotationProcessor,org.springframework.context.annotation.internalRequiredAnnotationProcessor,org.springframework.context.annotation.internalCommonAnnotationProcessor,org.springframework.context.annotation .internalPersistenceAnnotationProcessor,daoConfig,com.bjk.observation.server.config.DataSourceConfig#0,dataSource,com.bjk.observation.server.config.HibernateConfig#0,namingStrategy,sessionFactory,jdbcTemplate,txManager ,hibernateTemplate,現象羣島,現象島嶼,離散現象島嶼];工廠層次結構的根
- 253 [線程-0]錯誤org.springframework.web.context。ContextLoader
- 上下文初始化失敗org.springframework.beans.factory.BeanCreationException:創建名爲'daoConfig'的bean時出錯:注入自動裝配的依賴關係失敗;嵌套異常是org.springframework.beans.factory.BeanCreationException:無法自動裝入字段:private com.bjk.observation.server.config.HibernateConfig com.bjk.observation.server.config.DaoConfig.hibernateConfig;嵌套異常是org.springframework.beans.factory.BeanCreationException:創建名爲'com.bjk.observation.server.config.HibernateConfig#0'的bean時出錯:Bean實例化失敗;嵌套異常是org.springframework.beans.BeanInstantiationException:無法實例化bean類[com.bjk.observation.server.config.HibernateConfig]:構造函數拋出異常;嵌套的例外是顯示java.lang.NullPointerException
我不知道爲什麼這會有幫助,因爲標有@Configuration的類應該是它們自己的bean。儘管如此,我按照你的建議嘗試了,儘管我的錯誤日誌不同,但它仍然與未按正確順序初始化的bean有關。 (調試器證實了這一點。) 我把你關於@Configuration的觀點看作是對於工廠bean來說不是很好,事實上,我已經回到了老的可靠的XML配置,但我仍然想知道它是如何工作的。 – jhericks 2010-07-16 23:29:09