Spring注解配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| package com.bookstore.config;
import com.alibaba.druid.pool.DruidDataSource; import com.alibaba.druid.pool.DruidDataSourceFactory; import org.springframework.context.annotation.*; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.stereotype.Controller; import org.springframework.transaction.annotation.EnableTransactionManagement;
import javax.sql.DataSource; import java.util.Properties;
@Configuration @ComponentScan(value = "com.bookstore", excludeFilters = {@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = Controller.class)}) @EnableAspectJAutoProxy(proxyTargetClass = false) @EnableTransactionManagement() public class SpringConfig { @Bean public DruidDataSource getDataSource() { Properties dataSourceProperties = new Properties(); try { dataSourceProperties.load(SpringConfig.class.getClassLoader().getResourceAsStream("dataSource.properties")); return (DruidDataSource) DruidDataSourceFactory.createDataSource(dataSourceProperties); } catch (Exception e) { e.printStackTrace(); } return null; }
@Bean public JdbcTemplate getJdbcTemplate(DataSource dataSource) { JdbcTemplate jdbcTemplate = new JdbcTemplate(); jdbcTemplate.setDataSource(dataSource); return jdbcTemplate;
}
@Bean public DataSourceTransactionManager getDataSourceTransactionManager(DataSource dataSource) { DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager(); dataSourceTransactionManager.setDataSource(dataSource); return dataSourceTransactionManager; } }
|