整个项目的起步就在于各种配置文件,只要把配置文件搞好,后续开发才可以继续进行。
第一个配置文件:
spring配置文件applicationContext.xml
在这个文件中需要配置的有:
一、配置数据源
采用阿里巴巴的Druid连接池
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="colose">
<!--基本的属性driver,url,username,password-->
<property name="driverClassName" value="" />
<property name="url" value="" />
<property name="username" value="" />
<property name="password" value="" />
<!-- 初始化大小,初始化时建立物理连接的个数,初始化发生在显式调用init方法或第一个调用getConnention时 -->
<property name="initialSize" value="1" />
<!-- 最小连接池数量 -->
<property name="minIdle" value="1" />
<!-- 最大连接池数量 -->
<property name="maxActive" value="1" />
<!-- 获取连接时最大的等待时间,单位毫秒 -->
<property name="maxWait" value="10000" />
<!-- 间隔多久进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="60000" />
<!-- 一个连接在池中最小的生存时间,单位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="300000" />
<!-- 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效 -->
<property name="testWhileIdle" value="true" />
<!-- 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能 -->
<property name="testOnBorrow" value="false" />
<!-- 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能 -->
<property name="testOnReturn" value="false" />
<!-- 用来检测连接是否是有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会起作用。 -->
<property name="validationQuery" value="select 1" />
<!-- 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭 -->
<property name="poolPreparedStatements" value="true" />
<!-- 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100 -->
<property name="maxOpenPreparedStatements" value="100" />
<!-- 属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:监控统计用的filter:stat日志用的filter:log4j防御sql注入的filter:wall -->
<property name="filters" value="log4j" />
</bean>
二、对Mybatis进行集成
<!-- 创建SqlSessionFactoryBean -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 设置dataSource属性 -->
<property name="dataSource" ref="dataSource" />
<!-- 指定model层类名的别名扫描包,这与mapper配置中的paramterType和resultType搭配使用 -->
<property name="typeAliasesPackage" value="" />
<!-- 指定mybatis的mapper配置文件,支持classpath语法 -->
<property name="mapperLocations" value="classpath:*Mapper.xml/" />
<!-- Mybatis主配置文件路径,支持classpath语法 -->
<property name="configLocation" value="classpath:mybatis-config.xml" />
</bean>
<!-- spring与mybatis整合配置,扫描所有dao,指定的映射器必须是一个接口,而不是一个具体的实现类。-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.demo.dao" />
<!-- 没有必要去指定SqlSessionFactory 或 SqlSessionTemplate,因为MapperScannerConfigurer 将会创建MapperFactoryBean,之后自动装配。但是,如果你使用了一个以上的 DataSource,那么自动装配可能会失效 。这种情况下,你可以使用sqlSessionFactoryBeanName或sqlSessionTemplateBeanName属性来设置正确的bean名称来使用。 -->
</bean>
三、开启事务管理
<!-- 声明式事务(使用tx标签配置拦截器) -->
<!-- 需要导入aop、tx命名空间 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!--设置dataSource-->
<property name="dataSource" ref="dataSource" />
</bean>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- REQUIRED:事务执行方式,指定当前方法必需在事务环境中运行 -->
<tx:method name="方法名" propagation="REQUIRED" />
<tx:method name="方法名" propagation="REQUIRED" />
<tx:method name="方法名" propagation="REQUIRED" />
<!-- 指定当前方法以非事务方式执行操作,如果当前存在事务,就把当前事务挂起,等以非事务的状态运行完,再继续原来的事务。 查询定义即可,read-only="true" 表示只读 -->
<tx:method name="方法名" propagation="NOT_SUPPORTED" read-only="true" />
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut id="interceptorPointCuts" expression="execution(* com.demo.dao.*.*(..))" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="interceptorPointCuts" />
</aop:config>
第二个配置文件:
springMVC applicationContext-mvc.xml配置文件
在这个配置文件中主要启用spring注解驱动,进行静态资源配置,注解扫描配置和视图解析配置
<!-- 启用注解驱动,简单来说,要想使用注解就要有它 -->
<mvc:annotation-driven/>
<!-- 静态资源处理 -->
<!--
之所以要设置它,就是因为spring在配置DispathcerServlet是的url-pattern是"/",覆盖了tomcat
原有的DefaultServlet,DrfaultServlet主要处理静态资源,默认url-pattern也是"/",被spring覆盖了,
导致无法处理静态资源,所以必须要设置这一项,
-->
<mvc:default-servlet-handler/>
<!-- 也可以手动设置静态资源的路径 -->
<mvc:resources mapping="/static/**" location="/WEB-INF/static/" />
<!-- 指定要扫描的包的位置 -->
<!--
配置完这个标签后,spring就会去自动扫描base-package对应的路径或
者该路径的子包下面的java文件,如果扫描到文件中带有@Service,@Component,
@Repository,@Controller等这些注解的类,则把这些类注册为bean
-->
<context:component-scan base-package="com.demo" />
<!-- 配置Spring MVC的视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 控制器controller的返回值加前缀和后缀 -->
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
第三个配置文件:
web.xml
在web.xml中加载Spring配置,并且将所有的请求都过滤给Spring MVC来处理,同时设置编码过滤器解决编码问题。
<!-- 加载Spring容器配置 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Spring容器加载所有的配置文件的路径 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath*:spring/applicationContext.xml,
classpath*:spring/applicationContext-mvc.xml
</param-value>
</context-param>
<!-- DispatcherServlet配置 -->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:spring/applicationContext-mvc.xml</param-value>
</init-param>
<!--
用来标记是否在项目启动时就加在此Servlet,0或正数表示容器在应用启动时就加载这个Servlet,
当是一个负数时或者没有指定时,则指示容器在该servlet被选择时才加载.正数值越小启动优先值越高
-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--为DispatcherServlet建立映射-->
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- 设置编码过滤器 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
ssm基本开发环境搭建结束。
本文原地址悦来yuelai.xyz