1:后置通知的返回值问题日志
1.在后置通知中能够添加返回值,用来对返回值作处理。配置方法就是在xml文件中的后置通知配置项中,添加returning属性 returning="name" 属性的值就是用来接收参数的名称,这个名称必须是固定的不能随便更改。xml
2.后置通知与环绕通知一块儿使用时,若是后置通知须要返回值,那么在环绕通知中 必须添加返回值参数。否则目标对象执行的返回值就会被环绕通知所拦截。不会再往下传递参数。对象
2.异常通知返回值问题get
若是想得到异常信息。能够在异常通知中添加返回值为throwing="throwable"io
名称和后置通知同样都是固定的写法 应该和异常通知中的参数保持一致。咱们能够经过异常信息 作一个异常日志收集系统。使用AOP特别的方便。class
3.注解形式配置AOP配置
1.AOP注解开启aop
<aop:aspectj-autoproxy proxy-target-class="true"/>service
2.指明切面类方法
@Aspect
public class ReturnAspect
3.编写切入点
@Pointcut(value="execution(* service..*(..))")
public void pointcut(){
}
4.配置通知与切入点绑定
@Around(value="pointcut()")
public String around(ProceedingJoinPoint joinPoint) throws Throwable{
String name = (String) joinPoint.proceed();
System.out.println("!!!!!!!"+name);
return name;
}
注意事项
若是报错信息。中包含::0 应该检查切入点表达式中的返回值和通知中的参数是否匹配。
4.若是获得方法上的注解
@Around(value="execution(* service..*(..)) && @annotation(hello)")
public String around(ProceedingJoinPoint joinPoint,Hello hello)
这样利用Spring的机制可以快速的获取方法上的注解。便于之后注解的获取。