Pointcut可以有下列方式来定义或者通过&& || 和!的方式进行组合.
args()
@args()
execution()
this()
target()
@target()
within()
@within()
@annotation
其中execution 是用的最多的,其格式为:
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?)
ret-type-pattern:可以为*表示任何返回值,全路径的类名等.
name-pattern:指定方法名,*代表所以,set*,代表以set开头的所有方法.
parameters pattern:指定方法参数(声明的类型),(..)代表所有参数,(*)代表一个参数,(*,String)代表第一个参数为任何值,第二个为String类型.
举例说明:
任意公共方法的执行:
execution(public * *(..))
任何一个以“set”开始的方法的执行:
execution(* set*(..))
AccountService 接口的任意方法的执行:
execution(* .*(..))
定义在service包里的任意方法的执行:
execution(* .*.*(..))
定义在service包和所有子包里的任意类的任意方法的执行:
execution(* ..*.*(..))
定义在pointcutexp包和所有子包里的JoinPointObjP2类的任意方法的执行:
execution(* ..JoinPointObjP2.*(..))")
***> 最靠近(..)的为方法名,靠近.*(..))的为类名或者接口名,如上例的JoinPointObjP2.*(..))
pointcutexp包里的任意类.
within(.*)
pointcutexp包和所有子包里的任意类.
within(..*)
实现了Intf接口的所有类,如果Intf不是接口,限定Intf单个类.
this()
***> 当一个实现了接口的类被AOP的时候,用getBean方法必须cast为接口类型,不能为该类的类型.
带有@Transactional标注的所有类的任意方法.
@within()
@target()
带有@Transactional标注的任意方法.
@annotation()
***> @within和@target针对类的注解,@annotation是针对方法的注解,为自定义注解
如:
/** * 选取切入点为自定义注解 */
@Pointcut("@annotation()") public void permissionCheck(){}
@args()
参数为String类型(运行是决定)的方法.
args(String)
Pointcut 可以通过Java注解和XML两种方式配置,如下所示:
- <aop:config>
- <aop:aspectrefaop:aspectref="aspectDef">
- <aop:pointcutidaop:pointcutid="pointcut1"expression="execution(* ..JoinPointObjP2.*(..))"/>
- <aop:before pointcut-ref="pointcut1" method="beforeAdvice" />
- </aop:aspect>
- </aop:config>
- @Component
- @Aspect
- public class AspectDef {
- //@Pointcut("execution(* ..JoinPointObjP2.*(..))")
- //@Pointcut("within(..*)")
- //@Pointcut("this()")
- //@Pointcut("target()")
- //@Pointcut("@within()")
- //@Pointcut("@annotation()")
- @Pointcut("args(String)")
- public void pointcut1() {
- }
- @Before(value = "pointcut1()")
- public void beforeAdvice() {
- ("pointcut1 @Before...");
- }