对于最新的稳定版本,请使用 Spring Framework 6.2.10! |
声明方面
启用@AspectJ支持后,在应用程序上下文中定义的任何 bean 具有类,该类是@AspectJ方面(具有@Aspect
注释)会自动被 Spring 检测到并用于配置 Spring AOP。接下来的两个示例显示了不太有用的方面所需的最少步骤。
两个示例中的第一个示例显示了应用程序上下文中的常规 Bean 定义它指向一个 Bean 类,该 Bean 类用@Aspect
:
<bean id="myAspect" class="com.xyz.NotVeryUsefulAspect">
<!-- configure properties of the aspect here -->
</bean>
两个示例中的第二个示例显示了NotVeryUsefulAspect
类定义,即用@Aspect
:
-
Java
-
Kotlin
package com.xyz;
import org.aspectj.lang.annotation.Aspect;
@Aspect
public class NotVeryUsefulAspect {
}
package com.xyz
import org.aspectj.lang.annotation.Aspect
@Aspect
class NotVeryUsefulAspect
方面(用@Aspect
)可以具有方法和字段,与任何其他类相同。它们还可以包含切入点、建议和介绍(类型间) 声明。
通过组件扫描自动检测各个方面 您可以在 Spring XML 配置中将 aspect 类注册为常规 bean, 通过@Bean 方法@Configuration 类,或者让 Spring 通过类路径扫描 — 与任何其他 Spring 管理的 Bean 相同。但是,请注意@Aspect 注释不足以在类路径中进行自动检测。为此目的,您需要添加一个单独的@Component 注释(或者,根据 Spring 组件扫描器的规则,自定义stereotype 注释)。 |
将方面与其他方面提供建议? 在 Spring AOP 中,方面本身不能成为来自其他方面建议的目标 方面。 这@Aspect 类上的注释将其标记为一个方面,因此,将它排除在自动代理之外。 |