- 基于包名和类名进行过滤的类型签名表达式
- 根据实际签名过滤方法的方法签名表达式
- 用来过滤方法(这些方法以一种名称模式存在于Bean中)的Bean名称表达式
- 执行表达式
通过语法运算符and、or、not(或者&&、||和!),还可以混合使用这些表达式
一、类型签名表达式
为了根据类型(比如接口、类名或者包名过滤方法),SpringAOP提供了within
关键字。类型签名模式如下,其中可以使用package name或者class name替换type name。
Within(<type name>)
接下来列举一些类型签名用法的示例:
-
within(net.yangki..*)
:该通知将匹配net.yangki
包及其子包中所有类中的所有方法。 -
within(net.yangki.spring.demo.MyService)
:该通知将匹配MyService类中的所有方法。 -
within(MyServiceInterface+)
:该通知将匹配所有实现了MyServiceInterface接口的类的所有方法。 -
within(net.yangki.spring.demo.MyBaseService+)
:该通知将匹配MyBaseService类以及其子类的所有方法。
二、方法签名表达式
如果想根据方法签名进行过滤,可以使用关键字execution
。模式如下:
execution(<scope><return-type><fully-qualified-class-name>.*(parameters))
此时,对于与给定的作用域、返回类型、完全限定类名以及参数相匹配的方法,都会应用指定的通知。方法的作用域可以是公共的、保护的或者私有的。如果不想使用参数过滤,可以指定两个点..
,以表明方法可以接受任何数量和任何类型的参数。下面对方法签名的示例进行了简单的概述:
-
execute(* net.yangki.soring.demo.MyBean.*(..))
:该通知将匹配MyBean中的所有方法。 -
execute(public * net.yangki.spring.demo.MyBean.*(..))
:该通知将匹配MyBean中的所有公共方法。 -
execute(public String net.yangki.spring.demo.MyBean.*(..))
:该通知将匹配MyBean中的所有返回值为String类型的公共方法。 -
execute(public * net.yangki.spring.demo.MyBean.*(long,..))
:该通知将匹配MyBean第一个参数被定义为long的所有公共方法。
三、其他替代的切入点指示符
该部分将举例SpringAOP所支持的指示符。AOP仅支持在其他AOP项目中可用的指示符的一个子集。
-
bean(* Service)
:根据名称使用关键字bean进行过滤。该切入点表达式将与名称中带有后缀Service的Bean相匹配。 -
@annotation(net.yangki.spring.demo.MarkerMethodAnnotation)
:根据所应用的注解对方法进行过滤。该切入点表达式表明使用了MarkerMethodAnnotation
注解的方法将被通知。 -
within(net.yangki.spring.demo.MarkerAnnotation)
:当带有关键字within
的切入点表达式与一个包、类或者接口相匹配时,可以根据类所使用的注解限制对类的过滤。此时,使用了MarkerMethodAnnotation
注解的类将被@within
关键字通知。 -
This(net.yangki.spring.demo.MarkerInterface)
:该切入点表达式将对任何实现了MarkerInterface
接口的代理对象的方法进行过滤。
四、执行表达式
-
execution(public**(..))
:表明任何返回类型、类名和参数的任何公共方法都将被通知。
五、通配符
在定义表达式时,还可以使用通配符。比如*
、..
或者+
。如下表
通配符 | 定义 |
---|---|
.. |
该通配符匹配方法定义中的任何数量的参数,此外还匹配类定义中任何数量的包 |
+ |
该通配符匹配给定类的任何子类 |
* |
该通配符匹配任何数量的字符 |
网友评论