package com.websystique.springmvc.configuration;
import java.util.Properties;
import javax.sql.DataSource;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.core.env.Environment;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.hibernate4.HibernateTransactionManager;
import org.springframework.orm.hibernate4.LocalSessionFactoryBean;
import org.springframework.transaction.annotation.EnableTransactionManagement;
@Configuration
@EnableTransactionManagement
@ComponentScan({ "com.websystique.springmvc.configuration" })
@PropertySource(value = { "classpath:application.properties" })
public class HibernateConfiguration {
@Autowired
private Environment environment;
@Bean
public LocalSessionFactoryBean sessionFactory() {
LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
sessionFactory.setDataSource(dataSource());
sessionFactory.setPackagesToScan(new String[] { "com.websystique.springmvc.model" });
sessionFactory.setHibernateProperties(hibernateProperties());
return sessionFactory;
}
@Bean
public DataSource dataSource() {
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName(environment.getRequiredProperty("jdbc.driverClassName"));
dataSource.setUrl(environment.getRequiredProperty("jdbc.url"));
dataSource.setUsername(environment.getRequiredProperty("jdbc.username"));
dataSource.setPassword(environment.getRequiredProperty("jdbc.password"));
return dataSource;
}
private Properties hibernateProperties() {
Properties properties = new Properties();
properties.put("hibernate.dialect", environment.getRequiredProperty("hibernate.dialect"));
properties.put("hibernate.show_sql", environment.getRequiredProperty("hibernate.show_sql"));
properties.put("hibernate.format_sql", environment.getRequiredProperty("hibernate.format_sql"));
return properties;
}
@Bean
@Autowired
public HibernateTransactionManager transactionManager(SessionFactory s) {
HibernateTransactionManager txManager = new HibernateTransactionManager();
txManager.setSessionFactory(s);
return txManager;
}
}
@Configurationindica che questa classe contiene uno o più metodi di bean annotati con la @Beanproduzione di bean gestibili dal contenitore spring. Nel nostro caso, questa classe rappresenta la configurazione di ibernazione.
@ComponentScanè equivalente a context:component-scan base-package="..."in xml, fornendo dove cercare i bean / classi gestiti a molla.
@EnableTransactionManagementè equivalente a Spring's tx: * XML namespace, che abilita la capacità di gestione delle transazioni guidata da Spring.
@PropertySourceviene utilizzato per dichiarare un set di proprietà (definito in un file di proprietà nel percorso di classe dell'applicazione) in Spring run-time Environment, fornendo flessibilità per avere valori diversi in diversi ambienti applicativi.
Il metodo sessionFactory()sta creando un LocalSessionFactoryBean, che rispecchia esattamente la configurazione basata su XML: Abbiamo bisogno di un dataSource e di proprietà di ibernazione (come hibernate.properties). Grazie a @PropertySource, possiamo esternare i valori reali in un file .properties e utilizzare Spring's Environmentper recuperare il valore corrispondente a un elemento. Una volta che SessionFactory è stato creato, verrà iniettato nel metodo Bean transactionManagerche potrebbe eventualmente fornire il supporto delle transazioni per le sessioni create da sessionFactory.
Di seguito è riportato il file delle proprietà utilizzato in questo post.
/src/main/resources/application.properties
jdbc.driverClassName = com.mysql.jdbc.Driver
jdbc.url = jdbc:mysql://localhost:3306/websystique
jdbc.username = myuser
jdbc.password = mypassword
hibernate.dialect = org.hibernate.dialect.MySQLDialect
hibernate.show_sql = true
hibernate.format_sql = true