首页 > 编程语言 > 详细

Spring学习进度-05-AOP(二)

时间:2020-04-10 21:29:37      阅读:73      评论:0      收藏:0      [点我收藏+]

一、切面的优先级

基于Spring学习进度-04-AOP(一)案例代码,新建QiemianYouxianji.java

技术分享图片

技术分享图片
package aop;


import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

@Order(1)
@Aspect
@Component
public class QiemianYouxianji {
    
    @Before("Qiemian.declareExpression()")
    public void youxianji() {
         System.out.println("我最快");
    }

}
QiemianYouxianji.java

二、重用切点表达式

重写Qiemian.java

技术分享图片

 

 

技术分享图片
package aop;

import java.util.Arrays;
import java.util.List;

import org.aspectj.lang.JoinPoint;
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.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

//把这个类声明为一个切面,放到IOC容器,再声明为一个切面
@Order(2)
@Aspect
@Component
public class Qiemian {
    
    //定义一个方法用于声明切入点表达式,一般该方法不需注入其他方法
    //使用@Pointcut声明切入点表达式,后面只需调用该方法即可
    @Pointcut("execution(* aop.*.*(..))")
    public void declareExpression() {
        
    }

    //声明该方法是一个前置通知
    //@Before("execution(public int aop.Yunsuan.*(int,int))")
    //@Before("execution(* aop.*.*(int,int))")
    @Before("declareExpression()")
    public void before(JoinPoint joinpoint) {
        String name=joinpoint.getSignature().getName();
        List<Object> args=Arrays.asList(joinpoint.getArgs());
         System.out.println(name+" begin "+args);
    }
    
    //后置通知,目标方法执行后(无论异常)
    @After("declareExpression()")
    public void after(JoinPoint joinpoint) {
        String name=joinpoint.getSignature().getName();
        //不能返回目标方法执行的结果
        //List<Object> args=Arrays.asList(joinpoint.getArgs());
         System.out.println(name+" end ");
    }
    
    //返回通知,在方法正常结束后执行,,可以访问到方法的返回值
    @AfterReturning(value="declareExpression()",
            returning="result")
    public void afterReturning(JoinPoint joinpoint,Object result) {
        String name=joinpoint.getSignature().getName();
        System.out.println(name+" end with " + result);
    }
    
    //异常通知,在方法出现异常时执行,可以访问到异常对象
    @AfterThrowing(value="declareExpression()",
            throwing="e")
    public void afterThrowing(JoinPoint joinpoint,Exception e) {
        String name=joinpoint.getSignature().getName();
        System.out.println(name+" exception " + e);
    }
    
    //环绕通知,需携带ProceedingJoinPoint类型的参数,必须有返回值
    @Around("declareExpression()")
    public Object around(ProceedingJoinPoint pdj) {
        Object result=null;
        String name=pdj.getSignature().getName();
        //执行目标方法
        try {
            //前置通知
            System.out.println(name+" begin with " + Arrays.asList(pdj.getArgs()));
            result = pdj.proceed();
            //后置通知
            System.out.println(name+" end with " + Arrays.asList(pdj.getArgs()));
        } catch (Throwable e) {
            // TODO 自动生成的 catch 块
            //异常通知
            System.out.println(name+" exception " + e);
            throw new RuntimeException(e);
        }
        //后置通知
        System.out.println(name+" end ");
        return result;
    }
}
Qiemian.java

技术分享图片

 

Spring学习进度-05-AOP(二)

原文:https://www.cnblogs.com/MoooJL/p/12676066.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!