对于最新的稳定版本,请使用 Spring Framework 6.2.0spring-doc.cn

简明的代理定义

尤其是在定义交易代理时,您最终可能会得到许多类似的代理 定义。父 Bean 定义和子 Bean 定义以及内部 Bean 的使用 定义可以产生更简洁、更简洁的代理定义。spring-doc.cn

首先,我们为代理创建一个父级、模板、bean 定义,如下所示:spring-doc.cn

<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:spring-doc.cn

<bean id="myService" parent="txProxyTemplate">
	<property name="target">
		<bean class="org.springframework.samples.MyServiceImpl">
		</bean>
	</property>
</bean>

您可以覆盖父模板中的属性。在以下示例中, 我们覆盖交易传播设置:spring-doc.cn

<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 它。abstracttrueabstracttruespring-doc.cn