此版本仍在开发中,尚未被视为稳定版本。最新的稳定版本请使用 Spring Framework 6.1.13spring-doc.cn

此版本仍在开发中,尚未被视为稳定版本。最新的稳定版本请使用 Spring Framework 6.1.13spring-doc.cn

到目前为止,我们已经考虑了通过使用 或 类似的工厂豆。ProxyFactoryBeanspring-doc.cn

Spring 还允许我们使用 “auto-proxy” bean 定义,它可以自动 代理选定的 Bean 定义。这是建立在 Spring 的“bean post processor”之上的 基础结构,它允许在容器加载时修改任何 bean 定义。spring-doc.cn

在此模型中,您可以在 XML Bean 定义文件中设置一些特殊的 Bean 定义 配置自动代理基础架构。这样,您就可以声明目标 符合自动代理条件。您无需使用 .ProxyFactoryBeanspring-doc.cn

有两种方法可以执行此操作:spring-doc.cn

  • 通过使用引用当前上下文中特定 bean 的自动代理创建器。spring-doc.cn

  • 值得单独考虑的自动代理创建的特殊情况: 由源级元数据属性驱动的自动代理创建。spring-doc.cn

自动代理 Bean 定义

本节介绍包提供的自动代理创建者。org.springframework.aop.framework.autoproxyspring-doc.cn

BeanNameAutoProxyCreator

该类是自动创建 名称与 Literals 值或通配符匹配的 bean 的 AOP 代理。以下内容 示例展示了如何创建一个 bean:BeanNameAutoProxyCreatorBeanPostProcessorBeanNameAutoProxyCreatorspring-doc.cn

<bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
	<property name="beanNames" value="jdk*,onlyJdk"/>
	<property name="interceptorNames">
		<list>
			<value>myInterceptor</value>
		</list>
	</property>
</bean>

与 一样,有一个属性而不是一个列表 的拦截器,以允许原型 advisor 的正确行为。命名 “interceptors” 可以是顾问或任何建议类型。ProxyFactoryBeaninterceptorNamesspring-doc.cn

与一般的自动代理一样,使用的重点是 将相同的配置一致地应用于多个对象,并且最小体积为 配置。它是将声明式事务应用于多个 对象。BeanNameAutoProxyCreatorspring-doc.cn

名称匹配的 Bean 定义,例如前面的 和 例如,是具有 Target 类的普通旧 bean 定义。AOP 代理是 由 自动创建的 .同样的建议也适用 添加到所有匹配的 bean 中。请注意,如果使用 advisors(而不是 前面的示例),切入点可能以不同的方式应用于不同的 bean。jdkMyBeanonlyJdkBeanNameAutoProxyCreatorspring-doc.cn

DefaultAdvisorAutoProxyCreator

一个更通用且极其强大的自动代理创建器是 。这会自动将符合条件的顾问程序应用于 当前上下文,而无需在 auto-proxy 中包含特定的 bean 名称 顾问的 bean 定义。它提供了一致的配置和 避免重复为 。DefaultAdvisorAutoProxyCreatorBeanNameAutoProxyCreatorspring-doc.cn

使用此机制涉及:spring-doc.cn

  • 指定 Bean 定义。DefaultAdvisorAutoProxyCreatorspring-doc.cn

  • 在相同或相关上下文中指定任意数量的 advisor。请注意,这些 必须是顾问,而不是拦截器或其他建议。这是必要的, 因为必须有一个切入点进行评估,来检查每个建议的资格 添加到候选 bean 定义中。spring-doc.cn

自动评估包含的切入点 在每个 advisor 中,查看它应该适用于每个业务对象的建议(如果有) (例如示例中的 and)。DefaultAdvisorAutoProxyCreatorbusinessObject1businessObject2spring-doc.cn

这意味着可以自动将任意数量的顾问应用于每个业务 对象。如果任何 advisor 中都没有切入点与业务对象中的任何方法匹配,则 对象未被代理。当为新的业务对象添加 bean 定义时, 如有必要,它们会自动代理。spring-doc.cn

自动代理通常具有使调用者无法或 dependencies 获取 un-advised 对象。调用 this 将返回 AOP 代理,而不是目标业务对象。(“内部 bean“惯用语也提供了这个好处。getBean("businessObject1")ApplicationContextspring-doc.cn

下面的示例创建一个 Bean,另一个 本节讨论的元素:DefaultAdvisorAutoProxyCreatorspring-doc.cn

<bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"/>

<bean class="org.springframework.transaction.interceptor.TransactionAttributeSourceAdvisor">
	<property name="transactionInterceptor" ref="transactionInterceptor"/>
</bean>

<bean id="customAdvisor" class="com.mycompany.MyAdvisor"/>

<bean id="businessObject1" class="com.mycompany.BusinessObject1">
	<!-- Properties omitted -->
</bean>

<bean id="businessObject2" class="com.mycompany.BusinessObject2"/>

如果您想应用相同的建议,这将非常有用 始终如一地应用于许多业务对象。一旦基础设施定义就位, 您可以添加新的业务对象,而无需包含特定的代理配置。 您还可以轻松加入其他方面(例如,跟踪或 性能监控方面),对配置进行最小更改。DefaultAdvisorAutoProxyCreatorspring-doc.cn

提供对筛选的支持(通过使用命名 约定,以便仅评估某些 advisor,这允许使用多个 配置不同,AdvisorAutoProxyCreators 在同一个工厂中)和排序。 顾问可以实现该接口以确保 如果这是一个问题,请正确排序。用于 前面的示例具有可配置的 order 值。默认设置为 unordered。DefaultAdvisorAutoProxyCreatororg.springframework.core.OrderedTransactionAttributeSourceAdvisorspring-doc.cn