ContextLoaderListener配置未加载AbstractAnnotationConfigDispatcherServletInitialier

时间:2013-03-19 14:26:37

标签: spring spring-mvc

我使用Spring版本3.2.2.RELEASE。

我想创建一个带有hibernate的webapp并具有以下配置:

public class LifepulseServletInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {

@Override
protected Class<?>[] getRootConfigClasses() {
    return new Class[] { PersistenceConfig.class};
}

@Override
protected Class<?>[] getServletConfigClasses() {
    return new Class[] { LifepulseWebConfig.class };
}

@Override
protected String[] getServletMappings() {
    return new String[] { "/" };
}

@Override
protected WebApplicationContext createRootApplicationContext() {
    return super.createRootApplicationContext();
}

}

我的两个@Configuration注释文件如下所示:

我的 PersistenceConfig 应该用于ContextLoaderListener:

@Configuration
@EnableTransactionManagement(proxyTargetClass=true, mode=AdviceMode.PROXY)
public class PersistenceConfig{

Logger logger = LoggerFactory.getLogger(PersistenceConfig.class);

/** The Application Context. */
@Autowired
ApplicationContext context;

/**
 * Gets the database url.
 *
 * @return the database url
 */
@Bean(name="databaseUrl")
public String getDatabaseUrl(){
    return "jdbc:mysql://localhost/lifepulse";
}

/**
 * Gets the session factory properties.
 *
 * @return the session factory properties
 */
@Bean(name="sessionFactoryProperties")
public Properties getSessionFactoryProperties(){


    Properties props = new Properties();
    props.put("hibernate.dialect", MySQL5InnoDBDialect.class.getName());
    props.put("hibernate.hbm2ddl.auto", "create-drop");
    props.put("hibernate.show_sql", "true");
    props.put("hibernate.format_sql", "true");
    return props;
}


/** The Constant ANNOTATED_CLASSES. */
@SuppressWarnings("unchecked")
private static final Class<? extends Serializable>[] ANNOTATED_CLASSES=new Class[]{
    Melder.class,
    LogEntry.class
};


/**
 * Gets the annotated classes.
 *
 * @return the annotated classes
 */
private static Class<? extends Serializable>[] getAnnotatedClasses(){
    return ANNOTATED_CLASSES;
}

/**
 * Gets the data source.
 * This bean represents the application's MYSQL datasource, without using xml.
 *
 * @return the data source
 */
@Bean
public DataSource dataSource() {
    DriverManagerDataSource dataSource = new DriverManagerDataSource();
    dataSource.setDriverClassName("com.mysql.jdbc.Driver");
    dataSource.setUrl(getDatabaseUrl());
    dataSource.setUsername("lifepulse");
    dataSource.setPassword("lifepulse");
    return dataSource;
}

/**
 * Session factory.
 * This bean represents the Hibernate Session Factory. By declaring this bean
 * it can easily be injected into Spring DAOs later on.
 * 
 * @return the local session factory bean
 */
@Bean
public LocalSessionFactoryBean sessionFactory() {

    LocalSessionFactoryBean factory = new LocalSessionFactoryBean();
    factory.setAnnotatedClasses(getAnnotatedClasses());     
    factory.setHibernateProperties(getSessionFactoryProperties());
    factory.setDataSource(dataSource());
    return factory;
}

@Bean()
public GenericDao genericDao() {
    return new HibernateDaoImpl();
}

@Bean
PlatformTransactionManager txManager(){
    HibernateTransactionManager htm = new HibernateTransactionManager(sessionFactory().getObject());
    return htm;
}
}

我的 LifepulseWebConfig 应该用于DispatcherSerlvet:

@Configuration
@EnableWebMvc
@ComponentScan(value= {"com.ansiworks.lifepulse.controllers"})
@EnableTransactionManagement(proxyTargetClass=true, mode=AdviceMode.PROXY)
public class LifepulseWebConfig extends WebMvcConfigurerAdapter{ 
@Autowired
ApplicationContext context;


@Bean
ViewResolver viewResolver(){
    InternalResourceViewResolver resolver = new InternalResourceViewResolver();
    //resolver.setPrefix("");
    resolver.setSuffix(".jsp");
    return resolver;
}

@Bean
MainService mainService(){
    return new MainServiceImpl();
}

}

此配置不起作用。 dispathcer servlet不加载我的PersistenceConfig,因此bean不会被LifepulseWebConfig所占据。

但是:当我将 PersistenceConfig 添加到Method LifepulseServletInitializer#getServletConfigClasses()的类数组时,一切正常。 但是......我不能以这种方式使用sprin-security ....

我做错了什么!?为什么 LifepulseServletInitializer#getRootConfigClasses()返回的config-classes不被ContextLoaderListener读取?

我也尝试过这种方式(没有 LifepulseServletInitializer )具有相同的效果。我的 PersistenceConfig 的bean根本没有加载......

public class MyWebAppInitializer implements WebApplicationInitializer {

    @Override
    public void onStartup(ServletContext container) {
      // Create the 'root' Spring application context
      AnnotationConfigWebApplicationContext rootContext =
        new AnnotationConfigWebApplicationContext();
      rootContext.register(PersistenceConfig.class);

      // Manage the lifecycle of the root application context
      container.addListener(new ContextLoaderListener(rootContext));

      // Create the dispatcher servlet's Spring application context
      AnnotationConfigWebApplicationContext dispatcherContext =
        new AnnotationConfigWebApplicationContext();
      dispatcherContext.register(LifepulseWebConfig.class);

      // Register and map the dispatcher servlet
      ServletRegistration.Dynamic dispatcher =
        container.addServlet("dispatcher", new DispatcherServlet(dispatcherContext));
      dispatcher.setLoadOnStartup(1);
      dispatcher.addMapping("/");
    }

}

0 个答案:

没有答案