对于最新的稳定版本,请使用 Spring Framework 6.2.0! |
简明的代理定义
尤其是在定义交易代理时,您最终可能会得到许多类似的代理 定义。父 Bean 定义和子 Bean 定义以及内部 Bean 的使用 定义可以产生更简洁、更简洁的代理定义。
首先,我们为代理创建一个父级、模板、bean 定义,如下所示:
<bean id="txProxyTemplate" abstract="true"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager" ref="transactionManager"/>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
这本身永远不会实例化,因此它实际上可能是不完整的。然后,每个代理 需要创建的是一个子 Bean 定义,它包装了 proxy 作为内部 Bean 定义,因为无论如何,目标永远不会单独使用。 以下示例显示了这样的子 Bean:
<bean id="myService" parent="txProxyTemplate">
<property name="target">
<bean class="org.springframework.samples.MyServiceImpl">
</bean>
</property>
</bean>
您可以覆盖父模板中的属性。在以下示例中, 我们覆盖交易传播设置:
<bean id="mySpecialService" parent="txProxyTemplate">
<property name="target">
<bean class="org.springframework.samples.MySpecialServiceImpl">
</bean>
</property>
<property name="transactionAttributes">
<props>
<prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="load*">PROPAGATION_REQUIRED,readOnly</prop>
<prop key="store*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
请注意,在父 Bean 示例中,我们显式地将父 Bean 定义标记为
如前所述,通过将属性设置为 ,因此它可能实际上永远不会
实例。默认情况下,应用程序上下文(但不是简单的 bean 工厂)中,
预先实例化所有单例。因此,它很重要(至少对于 singleton bean)
也就是说,如果你有一个(父)Bean 定义,你只打算用作模板,
并且此定义指定了一个类,则必须确保将属性设置为 。否则,应用程序上下文实际上会尝试
pre-instantiate 它。abstract
true
abstract
true