通知类:
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注解的支持:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
">
<context:component-scan base-package="com.hehe"></context:component-scan>
<!-- 开启spring对AOP注解的支持 -->
<aop:aspectj-autoproxy/>
</beans>
当然如果觉得想彻底干掉配置文件,那么<aop:aspectj-autoproxy/>这句配置也可以写到配置类的注解中去: