在servlet 3.0 開始web專案可以完全不需要web.xml設定檔了,所以本文的設定只在支援servlet 3.0以上的web容器中有效
使用的是spring mvc (4.3.2.RELEASE) + thymeleaf (3.0.2.RELEASE), 持久層使用的spring的JdbcTemplate, PS:推薦一個很好用的對JdbcTemplate封裝的框架:https://github.com/selfly/dexcoder-assistant 。 以下開始具體的設定:
設定spring mvc DispatcherServlet
DispatcherServlet 是spring mvc的核心, Spring 提供了一個快速設定DispatcherServlet的類別 AbstractAnnotationConfigDispatcherServlet介面中的方法,用戶配置其他的filter 和listener
getRootConfigClasses() 獲取配置類,我理解的相當於applicationContext.xml 創建的上下文
getServletConfigClasses()獲取配置類,相當於mvc-servlet.xml 創建的上下文
不需要任何註解,
package com.liulu.bank.config; import org.springframework.web.WebApplicationInitializer; import org.springframework.web.filter.CharacterEncodingFilter; import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer; import javax.servlet.FilterRegistration; import javax.servlet.ServletContext; import javax.servlet.ServletException; import java.nio.charset.StandardCharsets; /** * User : liulu * Date : 2016-10-7 15:12 */ public class WebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer implements WebApplicationInitializer { @Override protected Class<?>[] getRootConfigClasses() { return new Class<?>[]{RootConfig.class}; } @Override protected Class<?>[] getServletConfigClasses() { return new Class<?>[]{WebConfig.class}; } /** * 配置DispatcherServlet 匹配的路径 * @return */ @Override protected String[] getServletMappings() { return new String[]{"/"}; } /** * 配置其他的 servlet 和 filter * * @param servletContext * @throws ServletException */ @Override public void onStartup(ServletContext servletContext) throws ServletException { FilterRegistration.Dynamic encodingFilter = servletContext.addFilter("encodingFilter", CharacterEncodingFilter.class); encodingFilter.setInitParameter("encoding", String.valueOf(StandardCharsets.UTF_8)); encodingFilter.setInitParameter("forceEncoding", "true"); encodingFilter.addMappingForUrlPatterns(null, false, "/*"); } }
配置 applicationContext.xml,由RootConfig類實作
package com.liulu.bank.config; import com.mchange.v2.c3p0.ComboPooledDataSource; import org.springframework.context.annotation.*; import org.springframework.core.env.Environment; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.stereotype.Controller; import org.springframework.transaction.PlatformTransactionManager; import org.springframework.transaction.annotation.EnableTransactionManagement; import javax.annotation.Resource; import javax.sql.DataSource; import java.beans.PropertyVetoException; /** * User : liulu * Date : 2016-10-7 15:36 */ @Configuration @PropertySource("classpath:config.properties") // 导入属性文件 @EnableAspectJAutoProxy // 相当于 xml 中的 <aop:aspectj-autoproxy/> @EnableTransactionManagement // 开启注解事务 @ComponentScan(basePackages = {"com.liulu.lit", "com.liulu.bank"}, excludeFilters = @ComponentScan.Filter(classes = Controller.class )) public class RootConfig { // 上面导入的属性文件中的属性会 注入到 Environment 中 @Resource private Environment env; /** * 配置数据库连接池 c3p0, * @return * @throws PropertyVetoException */ @Bean public DataSource dataSource() throws PropertyVetoException { ComboPooledDataSource dataSource = new ComboPooledDataSource(); dataSource.setJdbcUrl(env.getProperty("db.url")); dataSource.setDriverClass(env.getProperty("db.driver")); dataSource.setUser(env.getProperty("db.user")); dataSource.setPassword(env.getProperty("db.password")); dataSource.setMinPoolSize(Integer.valueOf(env.getProperty("pool.minPoolSize"))); dataSource.setMaxPoolSize(Integer.valueOf(env.getProperty("pool.maxPoolSize"))); dataSource.setAutoCommitOnClose(false); dataSource.setCheckoutTimeout(Integer.valueOf(env.getProperty("pool.checkoutTimeout"))); dataSource.setAcquireRetryAttempts(2); return dataSource; } /** * 配置事物管理器 * @param dataSource * @return */ @Bean public PlatformTransactionManager transactionManager(DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } @Bean public JdbcTemplate jdbcTemplate (DataSource dataSource) { return new JdbcTemplate(dataSource); } }
config.properties 檔案在resources 目
#数据库配置 db.url=jdbc:mysql://192.168.182.135:3306/bank db.driver=com.mysql.jdbc.Driver db.user=root db.password=123456 #数据库连接池配置 #连接池中保留的最小连接数 pool.minPoolSize=5 #连接池中保留的最大连接数 pool.maxPoolSize=30 #获取连接超时时间 pool.checkoutTimeout=1000