<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<bean id="sqlMapClient"
class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation"
value="classpath:sqlmapclient.xml">
</property>
</bean>
<!--
事务装备,做真正的事务处理
-->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<bean id="userDao" class="dao.impl.IbatisUsersDaoImpl">
<property name="sqlMapClient" ref="sqlMapClient"></property>
</bean>
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<bean id="realFacade" class="facade.Facade">
<property name="userDao" ref="userDao"></property>
</bean>
<!-- 配置抽象的aop-->
<bean id="abstractProxy" abstract="true"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager" ref="transactionManager" />
<property name="transactionAttributes">
<props>
<prop key="insert*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="delete*">PROPAGATION_REQUIRED</prop>
<prop key="login*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<!-- 配置具体的代理-->
<bean id="facade" parent="abstractProxy">
<property name="target" ref="realFacade"></property>
</bean>
<bean name="/login" class="struts.action.LoginAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/update" class="struts.action.UpdateAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/delete" class="struts.action.DeleteAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/insert" class="struts.action.InsertAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/getByUserName"
class="struts.action.GetByUserNameAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/getAll" class="struts.action.GetAllAction">
<property name="facade" ref="facade"></property>
</bean>
<bean name="/getPage" class="struts.action.GetPageAction">
<property name="facade" ref="facade"></property>
</bean>
</beans>
在ibatisfactory.abatorConfig.xml文件中的配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE abatorConfiguration PUBLIC "-//Apache Software Foundation//DTD Abator for iBATIS Configuration 1.0//EN"
"http://ibatis.apache.org/dtd/abator-config_1_0.dtd">
<abatorConfiguration>
<abatorContext> <!-- TODO: Add Database Connection Information -->
<jdbcConnection driverClass="com.microsoft.jdbc.sqlserver.SQLServerDriver"
connectionURL="jdbc:microsoft:sqlserver://localhost:1433;databaseName=pubs"
userId="sa"
password="">
<classPathEntry location="../WebRoot/WEB-INF/lib/msbase.jar" />
<classPathEntry location="../WebRoot/WEB-INF/lib/mssqlserver.jar" />
<classPathEntry location="../WebRoot/WEB-INF/lib/msutil.jar" />
</jdbcConnection>
<javaModelGenerator targetPackage="ibatis" targetProject="../src" />
<sqlMapGenerator targetPackage="ibatis" targetProject="../src" />
<daoGenerator type="IBATIS" targetPackage="dao1" targetProject="../src" />
<table schema="dbo" tableName="users">
<columnOverride column="userName" property="userName" />
<columnOverride column="sex" property="sex" />
<columnOverride column="birthday" property="birthday" />
<columnOverride column="pwd" property="pwd" />
</table>
</abatorContext>
</abatorConfiguration>
在运行中执行java -jar abator.jar abatorConfig.xml true