springboot aop里的@Pointcut()的配置
- @Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.test(String,String))")
com.wangzhou.newboot.exception是TestExceptionController类的全路径,test(String,String)是TestExceptionController类下的
test(String s,String d)方法
如果要忽略test方法的入参,所有test方法将被aop
- @Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.test(..))")
如果忽略TestExceptionController的方法,所有TestExceptionController下的方法将被aop
- @Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.*(..))")
如果忽略exception路径下的所有类,不包括exception的子路径
- @Pointcut("execution(public * com.wangzhou.newboot.exception.*.*(..))")
如果忽略newboot路径下的所有类,不包括newboot的子路径比如exception里的类,
- @Pointcut("execution(public * com.wangzhou.newboot..*.*(..))")
springboot aop @Pointcut的用法
格式:
- execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?)
括号中各个pattern分别表示:
- 修饰符匹配(modifier-pattern?)
- 返回值匹配(ret-type-pattern)可以为*表示任何返回值,全路径的类名等
- 类路径匹配(declaring-type-pattern?)
- 方法名匹配(name-pattern)可以指定方法名 或者 *代表所有, set* 代表以set开头的所有方法
- 参数匹配((param-pattern))可以指定具体的参数类型,多个参数间用“,”隔开,各个参数也可以用“*”来表示匹配任意类型的参数,如(String)表示匹配一个String参数的方法;(*,String) 表示匹配有两个参数的方法,第一个参数可以是任意类型,而第二个参数是String类型;可以用(..)表示零个或多个任意参数
- 异常类型匹配(throws-pattern?)
- 其中后面跟着“?”的是可选项
现在来看看几个例子:
- 1)execution(* *(..))
- //表示匹配所有方法
- 2)execution(public * com. savage.service.UserService.*(..))
- //表示匹配com.savage.server.UserService中所有的公有方法
- 3)execution(* com.savage.server..*.*(..))
- //表示匹配com.savage.server包及其子包下的所有方法
在Spring 2.0中,Pointcut的定义包括两个部分:Pointcut表示式(expression)和Pointcut签名(signature)
- //Pointcut表示式
- @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
- //Point签名
- private void log(){}
然后要使用所定义的Pointcut时,可以指定Pointcut签名
如下:
这种使用方式等同于以下方式,直接定义execution表达式使用
- @Before("execution(* com.savage.aop.MessageSender.*(..))")
Pointcut定义时,还可以使用&&、||、! 这三个运算
- @Pointcut("execution(* com.savage.aop.MessageSender.*(..))")
- private void logSender(){}
- @Pointcut("execution(* com.savage.aop.MessageReceiver.*(..))")
- private void logReceiver(){}
- @Pointcut("logSender() || logReceiver()")
- private void logMessage(){}
这个例子中,logMessage()将匹配任何MessageSender和MessageReceiver中的任何方法。
还可以将一些公用的Pointcut放到一个类中,以供整个应用程序使用,如下:
- package com.savage.aop;
- import org.aspectj.lang.annotation.*;
- public class Pointcuts {
- @Pointcut("execution(* *Message(..))")
- public void logMessage(){}
- @Pointcut("execution(* *Attachment(..))")
- public void logAttachment(){}
- @Pointcut("execution(* *Service.*(..))")
- public void auth(){}
- }
在使用上面定义Pointcut时,指定完整的类名加上Pointcut签名就可以了,如:
- package com.savage.aop;
- import org.aspectj.lang.JoinPoint;
- import org.aspectj.lang.annotation.*;
- @Aspect
- public class LogBeforeAdvice {
- @Before("com.sagage.aop.Pointcuts.logMessage()")
- public void before(JoinPoint joinPoint) {
- System.out.println("Logging before " + joinPoint.getSignature().getName());
- }
- }
当基于XML Sechma实现Advice时,如果Pointcut需要被重用,可以使用<aop:pointcut></aop:pointcut>来声明Pointcut,然后在需要使用这个Pointcut的地方,用pointcut-ref引用就行了,如:
- <aop:config>
- <aop:pointcut id="log" expression="execution(* com.savage.simplespring.bean.MessageSender.*(..))"/>
- <aop:aspect id="logging" ref="logBeforeAdvice">
- <aop:before pointcut-ref="log" method="before"/>
- <aop:after-returning pointcut-ref="log" method="afterReturning"/>
- </aop:aspect>
- </aop:config>
另外,除了execution表示式外,还有within、this、target、args等Pointcut表示式
以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。