引入
引入(在 AspectJ 中称为类型间声明)使方面能够声明被建议对象实现给定接口,并代表这些对象提供该接口的实现。
可以使用 @DeclareParents
注解进行引入。此注解用于声明匹配类型具有新的父类(因此得名)。例如,给定一个名为 UsageTracked
的接口和该接口的实现名为 DefaultUsageTracked
,以下方面声明所有服务接口的实现者也实现 UsageTracked
接口(例如,用于通过 JMX 进行统计)
-
Java
-
Kotlin
@Aspect
public class UsageTracking {
@DeclareParents(value="com.xyz.service.*+", defaultImpl=DefaultUsageTracked.class)
public static UsageTracked mixin;
@Before("execution(* com.xyz..service.*.*(..)) && this(usageTracked)")
public void recordUsage(UsageTracked usageTracked) {
usageTracked.incrementUseCount();
}
}
@Aspect
class UsageTracking {
companion object {
@DeclareParents(value = "com.xyz.service.*+",
defaultImpl = DefaultUsageTracked::class)
lateinit var mixin: UsageTracked
}
@Before("execution(* com.xyz..service.*.*(..)) && this(usageTracked)")
fun recordUsage(usageTracked: UsageTracked) {
usageTracked.incrementUseCount()
}
}
要实现的接口由带注解字段的类型确定。@DeclareParents
注解的 value
属性是 AspectJ 类型模式。任何匹配类型 Bean 都实现了 UsageTracked
接口。请注意,在前面示例的 before 建议中,服务 Bean 可以直接用作 UsageTracked
接口的实现。如果以编程方式访问 Bean,则应编写以下内容
-
Java
-
Kotlin
UsageTracked usageTracked = context.getBean("myService", UsageTracked.class);
val usageTracked = context.getBean("myService", UsageTracked.class)