`

利用TransactionProxyFactoryBean生成事务代理

阅读更多
一. 利用TransactionProxyFactoryBean生成事务代理
采用这种方式的配置时候,配置文件的增加非常快,每个bean有需要两个bean配置,一个目标,另外还需要使用TransactionProxyFactoryBean配置一个代理bean。
这是一种最原始的配置方式,下面是使用TransactionProxyFactoryBean的配置文件:
<?xml version="1.0" encoding="gb2312"?>
<!--  Spring配置文件的文件头,包含DTD等信息-->
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
    <!--定义数据源-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <!--  定义数据库驱动-->
            <property name="driverClassName"><value>com.mysql.jdbc.Driver</value></property>
        <!--  定义数据库url-->
            <property name="url"><value>jdbc:mysql://localhost:3306/spring</value></property>
        <!--  定义数据库用户名-->
            <property name="username"><value>root</value></property>
        <!--  定义数据库密码-->
            <property name="password"><value>32147</value></property>
    </bean>
    <!--定义一个hibernate的SessionFactory-->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <!--  定义SessionFactory必须注入DataSource-->
            <property name="dataSource"><ref local="dataSource"/></property>
            <property name="mappingResources">
            <list>
                <!--以下用来列出所有的PO映射文件-->
                <value>Person.hbm.xml</value>
            </list>
            </property>
            <property name="hibernateProperties">
            <props>
<!--此处用来定义hibernate的SessionFactory的属性:
不同数据库连接,启动时选择create,update,create-drop-->
            <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
        </props>
        </property>
    </bean>
    <!--  定义事务管理器,使用适用于Hibernte的事务管理器-->
<bean id="transactionManager"
        class="org.springframework.orm.hibernate3.HibernateTransactionManager">
            <!--  HibernateTransactionManager  bean需要依赖注入一个SessionFactory bean的引用-->
            <property name="sessionFactory"><ref local="sessionFactory"/></property>
    </bean>
    <!--定义DAO Bean , 作为事务代理的目标-->
    <bean id="personDaoTarget" class="lee.PersonDaoHibernate">
        <!--  为DAO bean注入SessionFactory引用-->
         <property name="sessionFactory"><ref local="sessionFactory"/></property>
    </bean>
    <!--  定义DAO bean的事务代理-->
<bean id="personDao" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
        <!--  为事务代理bean注入事务管理器-->
            <property name="transactionManager"><ref bean="transactionManager"/></property>
        <!--  设置事务属性-->
        <property name="transactionAttributes">
<props>
      <!--  所有以find开头的方法,采用required的事务策略,并且只读-->
                <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
      <!--  其他方法,采用required的事务策略 ->
                <prop key="*">PROPAGATION_REQUIRED</prop>
            </props>
        </property>
       <!--  为事务代理bean设置目标bean -->
        <property name="target">
            <ref local="personDaoTarget"/>
        </property>
    </bean>
</beans>
在上面的配置文件中,personDao需要配置两个部分,一个是personDao的目标bean,该目标bean是实际DAO bean,以实际的DAO bean为目标,建立事务代理。一个组件,需要来个bean组成,一个目标bean,一个事务代理。
这种配置方式还有一个坏处:目标bean直接暴露在Spring容器中,可以直接引用,如果目标bean被误引用,将导致业务操作不具备事务性。
为了避免这种现象,可将目标bean配置成嵌套bean,下面是目标bean和事务代理的配置片段:
<!--  定义DAO bean的事务代理-->
<bean id="personDao" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
         <!--  为事务代理bean注入事务管理器-->
        <property name="transactionManager"><ref bean="transactionManager"/></property>
        <!--  设置事务属性-->
        <property name="transactionAttributes">
              <props>
                    <!--  所有以find开头的方法,采用required的事务策略,并且只读-->
                    <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
                    <!--  其他方法,采用required的事务策略 ->
                    <prop key="*">PROPAGATION_REQUIRED</prop>
             </props>
        </property>
        <!--  为事务代理bean设置目标bean -->
        <property name="target">
               <!--  采用嵌套bean配置目标bean-->
               <bean class="lee.PersonDaoHibernate">
                  <!--  为DAO bean注入SessionFactory引用-->
                  <property name="sessionFactory"><ref local="sessionFactory"/></property>
               </bean>
        </property>
</bean>
分享到:
评论

相关推荐

    spring 事务管理例子(TransactionProxyFactoryBean代理机制 和 tx/aop)

    当你在业务方法上添加了这个注解,Spring就会在运行时动态生成一个代理,该代理会在方法调用前后管理事务。这使得代码更简洁,事务配置更直观。 在`tx`和`aop`的配合下,Spring会通过AOP代理拦截带有`@...

    详细说明spring事务配置的5种方式

    接下来,创建DAO Bean,例如`UserDaoImpl`,并配置`TransactionProxyFactoryBean`作为代理。代理Bean通过`transactionManager`属性引用`HibernateTransactionManager`,并通过`target`属性引用实际的DAO Bean。这样...

    Spring事务相关类Uml图

    在Spring框架中,事务...例如,`PlatformTransactionManager`的实现类如何与`TransactionDefinition`和`TransactionStatus`交互,`TransactionInterceptor`如何利用`TransactionAttribute`来决定事务的边界...

    Spring事务配置5种方式

    在这个例子中,Spring使用`TransactionProxyFactoryBean`创建了两个事务代理对象,一个是`userDao`,另一个是`userService`。这两个代理对象包裹了真实的DAO和Service对象,并且通过拦截器来处理事务的开始、提交、...

    Spring整合JDBC实现转账业务-动态代理模式

    1. `TransactionProxyFactoryBean`:这是一个Spring提供的特殊Bean工厂,用于创建事务代理。我们需要配置事务策略(如PROPAGATION_REQUIRED表示需要新事务)和目标对象。 2. `TransactionInterceptor`:这是Spring...

    spring_tx_aspectj方式源码

    前者负责创建事务代理,后者用于解析`@Transactional`注解并提供事务属性。 1. **TransactionProxyFactoryBean**:这是一个特殊的AOP代理工厂,用于创建具有事务处理能力的代理对象。它会根据事务属性生成代理代码...

    struts spring集成【下】

    它会基于AOP动态地生成一个代理,当业务方法执行时,如果发生异常,事务会被回滚;如果没有异常,事务会在方法结束时提交。例如: ```xml ...

    springMvc经典面试题

    声明式事务主要通过TransactionProxyFactoryBean来实现,它能够在运行时动态地为目标对象生成一个代理,将事务相关的操作封装在代理中,从而简化事务管理代码。 Spring MVC 还支持与SSH(Struts2、Spring、...

Global site tag (gtag.js) - Google Analytics