这是我的通知类:
package com.hehe.log;
import org.aspectj.lang.ProceedingJoinPoint;
public class MyLog {
//前置通知
public void printLog(){
System.out.println("打印日志!");
}
//后置通知
public void printLog1(){
System.out.println("打印日志!1");
}
//异常通知
public void printLog2(){
System.out.println("打印日志!2");
}
//最终通知
public void printLog3(){
System.out.println("打印日志!3");
}
//环绕通知
//执行这个方法的时候spring会自动为我们传入这个pjp
//所以说环绕通知其实就是另外四种通知的结合体,它就相当于invoke方法。
//环绕通知的好处就是,它比直接在配置文件里配通知更加灵活
public void aroundAdvice(ProceedingJoinPoint pjp) throws Exception{
try {
printLog();
pjp.proceed();
printLog1();
} catch (Throwable e) {
printLog2();
}finally{
printLog3();
}
}
}
4种常用的通知的配置(这是我别处截的图,跟上面类对不上。主要因为它注释比较清楚。。。):
最后一种环绕通知:
环绕通知其实就是另外四种通知的结合体,它就相当于invoke方法。环绕通知的好处就是,它比直接在配置文件里配通知更加灵活
<aop:pointcut expression="execution(* com.hehe.service.impl.*.*(..))" id="p1"/>
<aop:aspect id="logAspect" ref="logger">
<aop:around method="aroundAdvice" pointcut-ref="p1"/>
</aop:aspect>
可以看到只需配置环绕通知,其他的四种都不用配了,因为在环绕通知方法中都写好了!
版权声明:本文为dimples_qian原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。