Spring2.X以AspectJ 式AOP 配置事务

(1)配置: 
    Spring的事务管理是通过AOP代理实现的,其中的事务通知由元数据驱动。代理对象与事务元数据结合产生一个AOP代理,它使用一个PlatformTransactionManager实现,配合TransactionInterceptor,在方法调用前后实施事务。 

<?xml version="1.0" encoding="UTF-8"?>  
  
<beans xmlns="http://www.springframework.org/schema/beans"   
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
    xmlns:context="http://www.springframework.org/schema/context"   
    xmlns:aop="http://www.springframework.org/schema/aop"   
    xmlns:tx="http://www.springframework.org/schema/tx"   
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd   
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd   
    http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">  
  
    <description>springApp</description>      
    <!-- dataSource for MySQL -->  
    <bean id="dataSource"  
        class="org.apache.commons.dbcp.BasicDataSource"  
        destroy-method="close">  
        <property name="driverClassName"  
            value="com.mysql.jdbc.Driver" />  
        <property name="url"  
            value="jdbc:mysql://localhost:3306/springapp" />  
        <property name="username" value="root" />  
        <property name="password" value="****" />  
    </bean>     
  
    <!-- Hibernate SessionFactory for MySQL -->  
    <bean id="sessionFactory"  
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />  
  
        <property name="mappingDirectoryLocations">  
            <list>  
                <value>classpath:/</value>  
            </list>  
        </property>  
        <property name="hibernateProperties">  
            <props>  
                <prop key="hibernate.dialect">  
                    org.hibernate.dialect.MySQLDialect  
                </prop>  
                <prop key="hibernate.show_sql">true</prop>  
                <prop key="hibernate.jdbc.fetch_size">50</prop>  
                <prop key="hibernate.jdbc.batch_size">100</prop>  
            </props>  
        </property>  
  
    </bean>  
  
  
    <!--Transaction -->   
    <bean id="txManager"   
        class="org.springframework.orm.hibernate3.HibernateTransactionManager">   
            <property name="sessionFactory" ref="sessionFactory" />   
    </bean>   
  
    <aop:config> <!--use CGLIB:proxy-target-class="true-->  
        <aop:pointcut id="serviceOperator" expression="execution(* com.logcd.business.service.*.*(..))"/>  
        <aop:advisor  advice-ref="txAdvice" pointcut-ref="serviceOperator"/>   
        <!--  
        <aop:advisor pointcut="execution(* com.logcd.business.service..*Service.*(..))" advice-ref="txAdvice"/>         
        -->  
    </aop:config>   
      
    <tx:advice id="txAdvice" transaction-manager="txManager">   
        <tx:attributes>   
            <tx:method name="find*" read-only="true" />   
            <tx:method name="load*" read-only="true" />   
            <tx:method name="is*" read-only="true"/>   
            <tx:method name="save*"   
                rollback-for="Exception"/>   
            <tx:method name="insert*"   
                rollback-for="Exception" />   
            <tx:method name="remove*"  
                rollback-for="Exception"/>   
            <tx:method name="add*"  
                no-rollback-for="Exception" />   
        </tx:attributes>   
    </tx:advice>   
    <!--Transaction -->   
      
    <!-- DAO -->  
    <bean id="genericDao" lazy-init="true" abstract="true"  
        class="com.logcd.bo.dao.impl.GenericDaoImpl">  
        <property name="sessionFactory">  
            <ref local="sessionFactory" />  
        </property>  
    </bean>  
  
    <bean id="customersDao" parent="genericDao"  
        class="com.logcd.bo.dao.impl.CustomersDaoImpl" />  
  
    <bean id="customerDao" parent="genericDao"  
        class="com.logcd.bo.dao.impl.CustomerDaoImpl" />  
  
    <bean id="addressDao" parent="genericDao"  
        class="com.logcd.bo.dao.impl.AddressDaoImpl" />  
  
    <bean id="customerManageService"  
        class="com.logcd.business.service.impl.CustomerManageServiceImpl"  
        autowire="byName"/>  
          
</beans>  

(2)测试 

package com.logcd.test;  
  
import org.springframework.context.ApplicationContext;  
import org.springframework.context.support.ClassPathXmlApplicationContext;  
  
import com.logcd.bo.Customers;  
import com.logcd.business.service.CustomerManageService;  
  
import junit.framework.TestCase;  
  
public class SpringServiceTest extends TestCase {  
  
    private CustomerManageService customerManageService;   
      
    protected void setUp() throws Exception {  
        super.setUp();  
        ApplicationContext app = new ClassPathXmlApplicationContext("appContext.xml");  
        customerManageService = (CustomerManageService) app.getBean("customerManageService");  
    }  
  
    protected void tearDown() throws Exception {  
        super.tearDown();  
    }  
  
    public void testService() throws Exception{  
        Customers cus = new Customers();  
        cus.setName("testService");  
        cus.setAge(29);  
        customerManageService.saveCustomers(cus);  
    }  
}  


附:pointcut里的语法 
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws-pattern?)其中带问号的modifiers-pattern?(public/protected) 和 declaring-type-pattern? throws-pattern? 可以不填 

如execution(* *..BookManager.save(..)) 

第一颗* 代表ret-type-pattern 返回值可任意, 
*..BookManager 代表任意Pacakge里的BookManager类。 
如果写成com.xyz.service.* 则代表com.xyz.service下的任意类 
com.xyz.service..* com.xyz.service则代表com.xyz.service及其子package下的任意类 
save代表save方法,也可以写save* 代表saveBook()等方法 
(..) 匹配0个参数或者多个参数的,任意类型 
(x,..) 第一个参数的类型必须是X 
(x,,,s,..) 匹配至少4个参数,第一个参数必须是x类型,第二个和第三个参数可以任意,第四个必须是s类型。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值