Я использую Spring MVC 3.1.0M2 и пытаюсь переместить мои конфиги в Java-бины. Но я сталкиваюсь со следующей ошибкой:
2011-09-14 18: 43: 42.301: ПРЕДУПРЕЖДЕНИЕ: /: недоступно org.springframework.beans.factory.BeanCreationException: Ошибка создания бина с именем 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration # 0': внедрение сбой автосвязанных зависимостей; вложенным исключением является org.springframework.beans.factory.BeanCreationException: не удалось автоматически подключить метод: void org.springframework.transaction.annotation.AbstractTransactionManagementConfiguration.setConfigurers (java.util.Collection); вложенное исключение - org.springframework.beans.factory.BeanCreationException: ошибка создания бина с именем entityManagerFactory, определенного в классе ru.mystamps.web.config.DbConfig: сбой создания бина; вложенным исключением является org.springframework.beans.factory.BeanDefinitionStoreException: фабричный метод [public org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean ru.mystamps.web.config.DbConfig.entityManagerFactory thception) Вложенное исключение - java.lang.IllegalArgumentException: DataSource не должен быть нулевым
Отображение из web.xml
:
<context-param>
<param-name>spring.profiles.default</param-name>
<param-value>dev</param-value>
</context-param>
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<init-param>
<param-name>contextClass</param-name>
<param-value>
org.springframework.web.context.support.AnnotationConfigWebApplicationContext
</param-value>
</init-param>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>
ru.mystamps.web.config.MvcConfig,
ru.mystamps.web.config.DbConfig
</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
DbConfig.java
:
@Configuration
@EnableTransactionManagement
@ImportResource("classpath:spring/datasource.xml")
public class DbConfig {
@Autowired
private DataSource dataSource;
@Bean
public JpaVendorAdapter jpaVendorAdapter() {
final HibernateJpaVendorAdapter jpaVendorAdapter =
new HibernateJpaVendorAdapter();
jpaVendorAdapter.setDatabasePlatform(dialectClassName);
jpaVendorAdapter.setShowSql(showSql);
return jpaVendorAdapter;
}
@Bean
public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
final LocalContainerEntityManagerFactoryBean entityManagerFactory =
new LocalContainerEntityManagerFactoryBean();
entityManagerFactory.setJpaVendorAdapter(jpaVendorAdapter());
entityManagerFactory.setDataSource(dataSource);
final Map<String, String> jpaProperties = new HashMap<String, String>();
jpaProperties.put("hibernate.format_sql", formatSql);
jpaProperties.put("hibernate.connection.charset", "UTF-8");
jpaProperties.put("hibernate.hbm2ddl.auto", hbm2ddl);
entityManagerFactory.setJpaPropertyMap(jpaProperties);
return entityManagerFactory;
}
@Bean
public PlatformTransactionManager transactionManager() {
final JpaTransactionManager transactionManager =
new JpaTransactionManager();
transactionManager.setEntityManagerFactory(entityManagerFactory().getObject());
return transactionManager;
}
...
}
spring/datasource.xml
:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:jdbc="http://www.springframework.org/schema/jdbc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc-3.1.xsd">
<context:property-placeholder location="classpath:spring/database.properties" />
<beans profile="dev">
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${db.driverClassName}" />
<property name="url" value="${db.url}" />
<property name="username" value="${db.username}" />
<property name="password" value="${db.password}" />
</bean>
</beans>
<beans profile="test">
<jdbc:embedded-database id="dataSource" type="HSQL">
<jdbc:script location="classpath:test-data.sql" />
</jdbc:embedded-database>
</beans>
</beans>
Я ожидаю, что бин dataSource
будет создан после импорта datasource.xml
, но я всегда получал эту ошибку.
ТИА