用注解的方式配置AOP

通知类:

package com.hehe.log;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

@Component("logger")    //我们需要将通知类实例化以用其各种通知方法
@Aspect                //表示它是一个切面
public class MyLog {
        
        //这里在定义切入点,这里写一个方法,后面直接引用方法名就行!
	@Pointcut("execution(* com.hehe.service.impl.*.*(..))")
	private void p1(){};
	
	//前置通知
	@Before("p1()")
	public void printLog(){
		System.out.println("打印日志!");
	}
	
	//后置通知
	@AfterReturning("p1()")
	public void printLog1(){
		System.out.println("打印日志!1");
	}
	
	//异常通知
	@AfterThrowing("p1()")
	public void printLog2(){
		System.out.println("打印日志!2");
	}
	
	//最终通知
	@After("p1()")
	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();
		}
		
	}
}

记住bean.xml中要添加aop对应约束,还要配置一句话开启spring对AOP注解的支持:



 
	
	
	
	

 

当然如果觉得想彻底干掉配置文件,那么这句配置也可以写到配置类的注解中去:

 用注解的方式配置AOP_第1张图片

你可能感兴趣的:(Spring)