关于spring中的5种常用通知

这是我的通知类:

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版权协议,转载请附上原文出处链接和本声明。