二、spring集成ibatis进行数据源事务管理拦截器环境配置
1、dataSource-applicationContext.xml文件配置理解:(spring1.2.8+ibatis1.5.3)
1.1)配置数据源
DriverManagerDataSource:类实现了 SmartDataSource接口。可以使用bean properties来设置JDBC Driver属性,该类每次返回的都是一个新的连接。 <beans> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" destroy-method="close"> <property name="driverClassName"> <value>oracle.jdbc.driver.OracleDriver</value> </property> <property name="url"> <value>jdbc:oracle:thin:@...:1521:LIFERPT</value> </property> <property name="username"> <value>...</value> </property> <property name="password"> <value>...</value> </property> </bean> <!--实际生产中是通过配置weblogic的控制域下面的数据源来进行数据库链接 <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName"> <value>ReportDB</value> </property> </bean> <!-- 创建SqlMapClient 使用iBATIS 2.x来映射刚才的那个Account类,则需要创建这样一个SQL map Account.xml iBATIS2的配置文件 <sqlMapConfig> <sqlMap resource="example/Account.xml"/> </sqlMapConfig> iBATIS从CLASSPATH下加载资源,所以必须确保 Account.xml 在CLASSPATH下。 可以使用Spring container中的 SqlMapClientFactoryBean。 注意iBATIS SQL Map 2.x中,JDBC DataSource 通常由 SqlMapClientFactoryBean 指定,并开启了延迟加载。 -->
1.2)设置ibatis
<!-- SqlMapClientFactoryBean的主要的几个属性: 1 configLocations --ibatis的配置文件的地址 2 mappingLocations --Ibatis映射文件路径 3 sqlMapClientProperties --ibatis的sqlmapclient的属性 4 dataSource --数据源 5 useTransactionAwareDataSource --使用spring 的事务包装数据源 6 transactionConfigClass --事物配置类 7 transactionConfigProperties --事物配置属性 8 sqlMapClient --> <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> <property name="configLocation"> <value> /WEB-INF/classes/org/bussiness/config/ibatis/SqlMapConfig.xml </value> </property> <property name="dataSource"> <ref local="dataSource" /> </property> </bean>
1.3)配置视图解析器
<!-- 为将返回的viewname映射到对应的jsp上,在servlet context 配置文件中是这么定义的. UrlBasedViewResolver将使用JstlView对象来渲染结果,并将handler method返回的modelAndView基础上,加上目录前缀/WEB-INF/jsp/和文件名称后缀.jsp。 例如return new ModelAndView(kyDataMannualExtract, map); 结果返回的viewName为kyDataMannualExtract,则对应的实际jsp为/WEB-INF/jsp/kyDataMannualExtract.jsp 当返回的viewName的前缀为forward:时,spring mvc将结果通过forward的方式转到对应的视图,例如forward:helloworld。这也是spring mvc缺省的使用模式。 当返回的viewName的前缀为redirect:时,spring mvc将结果通过redirect的方式转到对应的视图。例如redirect:helloworld --> <bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" /> <property name="prefix" value="/jsp/" /> <property name="suffix" value=".jsp" /> </bean>
1.4)配置spring的简单url拦截器
<!-- SimpleUrlHandlerMapping 是Spring的一种拦截器,用于在XML文件中配置以拦截url,它是以map映射的方式进行拦截。映射是从前台urls到具体后台的beans。 同时支持到bean实例和bean名称的映射,后者要求非单实例控制。urlMap适用于映射到bean引用,而mappings适用于映射到bean的名字。 --> <bean id="urlMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> <property name="mappings"> <description>这里添加URL和处理bean的映射</description> <props> <prop key="usherAction.do">usherAction</prop> <prop key="personalAction.do">personalAction</prop> <prop key="organizeAction.do">organizeAction</prop> <prop key="nationalAction.do">nationalAction</prop> <prop key="genQueryAction.do">genQueryAction</prop> <prop key="engineLoadAction.do">engineLoadAction</prop> </props> </property> </bean>
1.5)配置事务管理器
<!-- DataSourceTransactionManager类是PlatformTransactionManager接口的一个实现,用于处理单JDBC数据源。它将从指定DataSource取得的JDBC连接绑定到当前线程, 因此它也支持了每个数据源对应到一个线程DataSourceTransactionManager类支持定制隔离级别,以及对SQL语句查询超时的设定。事务模块的配置,我们抽象出Service层, 也是为了方便事务操作,可能一组业务需要操作多个DAO,那么显然不能在DAO层做事务,而在业务层做事务是非常合适的,也符合逻辑,我们使用Spring提供的 DataSourceTransactionManager来配置事务管理器: --> <bean id="ibatisTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource"> <ref local="dataSource" /> </property> </bean> <bean id="paraMethodResolver" class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver"> <property name="paramName"> <value>action</value> </property> </bean>
1.6)spring进行事务管理配置
配置事务模板,模板bean被设置成abstract bean,保证不会被初始化 lazy-init:表示在请求的时候才会被加载属于懒加载 配置:ServiceAop(TransactionProxyFactoryBean)这个事务代理工厂bean是为了将业务层交给spring进行事务管理 <bean id="ServiceAop" lazy-init="true" abstract="true" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"> <!--设置事务属性--> <property name="transactionAttributes"> <props> <!--所有以insert开头的方法,采用required的事务策略,//propagation推广--> <prop key="insert*">PROPAGATION_REQUIRED</prop> <prop key="update*">PROPAGATION_REQUIRED</prop> <!--所有以get开头的方法,采用required的事务策略,并且只读--> <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop> <prop key="check*">PROPAGATION_REQUIRED,readOnly</prop> </props> </property> </bean>
1.7)国际化处理
<!-- Spring目前提供了两个MessageSource的实现:ResourceBundleMessageSource和StaticMessageSource。 它们都继承NestingMessageSource以便能够处理嵌套的消息。StaticMessageSource很少被使用,但能以编程的方式向消息源添加消息。 ResourceBundleMessageSource会用得更多一些。备注:ApplicationContext实现了MessageSource接口 下面配置的含义表示:通过ResourceBundle,使用JDK中解析消息的标准方式,来处理任何解析消息的请求。testmess文件中内容为userinfo =cms 如何测试: public static void main(String[] args) { MessageSource resources = new ClassPathXmlApplicationContext("beans.xml"); String message = resources.getMessage("message", null, "Default", null); System.out.println(message); } --> <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource"> <property name="basenames"> <list> <value>org/properties/testmess</value> </list> </property> </bean> </beans>
1.8)映射文件编写
该文件所在路径:src\org\bussiness\config\ibatis\SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN" "http://www.ibatis.com/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<sqlMap resource="org/bussiness/config/ibatis/oraclesqlmap/TreeSQL.xml"/>
<sqlMap resource="org/bussiness/config/ibatis/oraclesqlmap/ListReportOrg.xml"/>
<sqlMap resource="org/bussiness/config/ibatis/oraclesqlmap/PersonalSQL.xml"/>
</sqlMapConfig>
2、upload-applicationContext.xml
<beans> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding" value="utf-8" /> </bean> <bean id="engineLoadAction" class="org.upload.EngineLoadAction"> <property name="methodNameResolver"> <ref bean="paraMethodResolver"/> </property> <property name="engineService"> <ref local="engineService"/> </property> <property name="orgService"> <ref bean="orgService"/> </property> <property name="seqService"> <ref bean="seqService" /> </property> <property name="xmlUpload"> <value>upload/xmlUpload</value> </property> </bean> <bean id="engineService" class="org.upload.service.EngineService"> <property name="engineLoadDao"> <ref local="engineLoadDao"/> </property> <property name="seqService"> <ref bean="seqService" /> </property> <property name="personalDao"> <ref bean="personalDao"/> </property> </bean> <bean id="engineLoadDao" class="org.upload.dao.EngineLoadDao"> <property name="dataSource"> <ref bean="dataSource"/> </property> <property name="sqlMapClient"> <ref bean="sqlMapClient"/> </property> </bean> <!--AOP事务声明--> <bean id="engineServiceAop" parent="ServiceAop"> <property name="target"> <ref local="engineService" /> </property> </bean> </beans>
3、web.xml文件配置
<servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class> org.springframework.web.servlet.DispatcherServlet </servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value> /WEB-INF/conf/dataSource-applicationContext.xml, /WEB-INF/conf/upload-applicationContext.xml </param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
细水长流,打磨濡染,渐趋极致,才是一个人最好的状态。