当前位置: 首页 > article >正文

springboot中的AOP以及面向切面编程思想

快速入门体验AOP

aop中相关概念

实现导入依赖

<dependency>  
    <groupId>org.springframework.boot</groupId>  
    <artifactId>spring-boot-starter-aop</artifactId>  
</dependency>

新建aop文件夹,里面声明XXXAspect类 

@Aspect // 声明一个aop类
@Component
public class RecordTimeAspect {
    private static final Logger log = (Logger) LoggerFactory.getLogger(RecordTimeAspect.class);
    // 切入点表达式
    @Around("execution(* com.managerweb.service.ServiceImpl.*.*(..))") // 测试业务层的所有方法
    public Object RecordTime(ProceedingJoinPoint pjp) throws Throwable {
        long begin = System.currentTimeMillis();
        Object result = pjp.proceed(); // 这表示执行所有@Around里声明的方法
        long end = System.currentTimeMillis();
        // getSignature()获取方法名称
        log.info("方法{}运行时间为{}",pjp.getSignature(), (end - begin));
        return result;
    }
}

AOP的底层原理:动态代理

通知

根据通知方法执行时机的不同,将通知类型分为以下常见的五类:

  1. @Around: 环绕通知,此注解标注的通知方法在目标方法前、后都被执行
  2. @Before: 前置通知,此注解标注的通知方法在目标方法前被执行
  3. @After: 后置通知,此注解标注的通知方法在目标方法后被执行,无论是否有异常都会执行
  4. @AfterReturning: 返回后通知,此注解标注的通知方法在目标方法返回后执行,有异常不会执行
  5. @AfterThrowing: 异常后通知,此注解标注的通知方法发生异常时执行
     
  • 注意1:@Around环绕通知需要自己调用 ProceedingJoinPoint.proceed() 来让原始方法执行,其它通知不需要考虑目标方法执行
  • 注意2:@Around环绕通知方法的返回值,必须指定为Object,以接收目标方法的返回值。

抽取切入点表达式

抽取的原因:由于切入点表达式总是出现,为了简化,在最开始时将切入点表达式抽取出来

具体使用如下 

    @Pointcut("execution(* com.managerweb.service.ServiceImpl.*.*(..))")
    private void pt(){}

    @Around("pt()") // 测试业务层的所有方法
    public Object RecordTime(ProceedingJoinPoint pjp) throws Throwable {
        long begin = System.currentTimeMillis();
        Object resu

http://www.kler.cn/a/447413.html

相关文章:

  • 智能座舱进阶-应用框架层-Handler分析
  • Vue之版本演进
  • JNDI基础
  • 1. JasperSoft介绍与安装
  • LLaMA-Factory 单卡3080*2 deepspeed zero3 微调Qwen2.5-7B-Instruct
  • 数据结构漫游记:初识vector
  • Vue.js前端框架教程8:Vue消息提示ElMessage和ElMessageBox
  • Win/Mac 如何实现测试 IP 和端口
  • ​在VMware虚拟机上设置Ubuntu与主机共享文件夹​
  • ubuntu 开机自动mount 的方法
  • 行情接入手册
  • 信息安全管理与评估赛题第6套
  • 【初阶数据结构与算法】八大排序算法之选择排序(直接选择排序、堆排)
  • 使用C#绘制具有平滑阴影颜色的曼德布洛特集分形
  • 国产操作系统openEuler22.09系统OpenStackYoga 部署指南
  • [笔记]关于Qt的nativeEvent事件无法接收window消息的Bug
  • 【从零开始入门unity游戏开发之——C#篇17】C#面向对象的封装——类(Class)和对象、成员变量和访问修饰符、成员方法
  • Liquibase结合SpringBoot使用实现数据库管理
  • 使用 mstsc 远程桌面连接时无法复制粘贴本地文件或文字解决方法
  • SAP PP ECN CSAP_MAT_BOM_MAINTAIN
  • run postinstall error, please remove node_modules before retry!
  • PyTorch实战-模拟线性函数和非线性函数
  • 基于matlab的单目相机标定
  • C语言 文件操作——按字符读写文件
  • uni-app开发商品分类页面实现
  • 奇怪问题| Chrome 访问csdn 创作中心的时候报错: 服务超时,请稍后重试