Spring的AOP五大通知注解

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_38409944/article/details/82695537

通知注解 :

声明方法,在方法前加入通知注解,指定要拦截的对象信息 

注意:

* 代表任意修饰符号 任意值

AOP五大通知注解:

@Before 前置通知,在方法执行之前执行
@After  后置通知,在方法执行之后执行(无论是否发生异常)还不能访问目标方法执行的结果
@AfterRunning 返回通知,在方法正常结束后 返回结果之后执行 可以访问方法的返回值
@AfterThrowing 异常通知,在方法抛出异常之后
@Around 环绕通知,围绕着方法执行

一张图看看这些通知对应在动态代理中的位置:
这里写图片描述
来分别测试这五大注解。
配置已经在前一章写过了,直接拿来用:

链接:Spring+Maven+Aspectj的AOP实现对指定对象的切面拦截

修改下add方法:

@Override
    public int add(int a, int b) {
        System.out.println("执行add方法");
        return a+b;
    }

@Before :前置通知,在方法执行之前执行

@Aspect
@Component
public class MyAspect {

    @Before("execution(* calculator.CalculatorImpl.*(..))")
    public void beforeMethod(JoinPoint joinpoint){
        String methodName = joinpoint.getSignature().getName();
        List<Object> list = Arrays.asList(joinpoint.getArgs());
        System.out.println("方法:"+methodName+" 参数是"+list);
    }
}

输出:

方法:add 参数是[1, 2]
执行add方法
3

@After 后置通知,在方法执行之后执行(无论是否发生异常)还不能访问目标方法执行的结果:

@After("execution(* calculator.CalculatorImpl.*(..))")
    public void afterMethod(JoinPoint joinpoint){
        String methodName = joinpoint.getSignature().getName();
        List<Object> list = Arrays.asList(joinpoint.getArgs());
        System.out.println("方法:"+methodName+" 参数是"+list);
    }

输出:

执行add方法
方法:add 参数是[1, 2]
3

@AfterRunning 返回通知,在方法正常结束后 返回结果之后执行 可以访问方法的返回值:

 @AfterReturning(value = "execution(* calculator.CalculatorImpl.*(..))",returning = "result")
    public void afterMethod(JoinPoint joinpoint,Object result){
        String methodName = joinpoint.getSignature().getName();
        System.out.println("方法:"+methodName+" 返回值:"+result);
    }

输出:

执行add方法
方法:add 返回值:3
3

@AfterThrowing 异常通知,在方法抛出异常之后执行。
可以访问到异常对象,而且可以指定在出现特定异常时再通知代码。

@AfterThrowing(value = "execution(* calculator.CalculatorImpl.*(..))",throwing = "ex")
    public void afterMethod(JoinPoint joinpoint,Exception ex){
        String methodName = joinpoint.getSignature().getName();
        System.out.println("方法:"+methodName+"异常原因:"+ex);
    }

@Around 环绕通知,围绕着方法执行

它的范围更大,其实就相当于动态代理,包含了整个通知的过程。
它的方法返回值就是 拦截方法的返回值。

@Around("execution(public * calculator.CalculatorImpl.*(..))")
    public Object aroundMethod(ProceedingJoinPoint proceedingJoinPoint){
        Object result = null;
        String methodName = proceedingJoinPoint.getSignature().getName();
        try {
            System.out.println("前置通知返回执行的方法:"+methodName+Arrays.asList(proceedingJoinPoint.getArgs()));
            result = proceedingJoinPoint.proceed();
            System.out.println("返回通知的结果是:"+result);
        }catch (Throwable throwable) {
            throwable.printStackTrace();
            System.out.println("异常返回");
        }
        System.out.println("后置通知:"+methodName);
        result =100;
        return result;
    }

输出:

前置通知返回执行的方法:add[1, 2]
执行add方法
返回通知的结果是:3
后置通知:add
100

注意:
在过程中 我修改了result的值,结果方法调用的返回值就是我修改后的值。

猜你喜欢

转载自blog.csdn.net/qq_38409944/article/details/82695537