IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot项目使用AOP实现接口调用日志 -> 正文阅读

[Java知识库]SpringBoot项目使用AOP实现接口调用日志

目录

简介

前置准备工作

开始使用AOP

总结

注意事项


简介

项目中,使用AOP是一种常见的设计方式,可以在不侵入业务代码的前提下,对业务进行增强,springboot中事务注解@Transactional就是使用了AOP进行动态代理去实现事务,常见的AOP方式比如前置通知(增强)、后置通知、异常通知、环绕通知、最终通知,合适的AOP方式可以极大降低业务代码的冗余与侵入性,是开发中必不可少的一环。

本文使用了AOP中的AROUND ADVICE(环绕通知)进行接口日志处理


前置准备工作

导入Sping整合AOP的场景依赖启动器,已整合了切入点表达式和AOP

<!--AOP启动器-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
    <version>2.5.6</version>
</dependency>

开始使用AOP

1.定义自定义注解 @AutoLog

@Target(value = {ElementType.METHOD,ElementType.TYPE})
@Retention(value = RetentionPolicy.RUNTIME)
public @interface AutoLog {
    String value() default "";
}

2.定义切面类 LogAspect.java

@Component
@Aspect
@Slf4j
public class LogAspect{
    //自定义切入点 代理每一个打上@AutoLog注解的类
    @Pointcut(value = "@within(io.binarymei.annotation.AutoLog)")
    public void AutoLog(){}
}

3.使用环绕通知进行增强

//定义环绕通知 增强打上AutoLog注解的类中所有方法
@Aroud(value = "AutoLog()")
public Object AutoLogAround(ProceedingJoinPoint proceedingJoinPoint){
    try{
        //前置通知
        //执行被增强的方法
        Object proceed = proceedingJoinPoint.proceed();
        //后置通知
    }catch(Exception e){
        //异常通知
    }finally{
        //最终通知
    }
}

总结

? ? ? ? 这样,一个使用AOP环绕通知进行接口调用日志记录的小例子就完成了,打上注释的那些都是可以自由填写自己所需要的业务,比如记录接口的调用时间,请求信息,参数信息,以及响应信息,调用状态等等。

注意事项

? ? ? ? 若被增强的方法出现异常时,由于自己手动捕获了异常,会导致全局异常处理器失效,以及如果此方法使用了事务,则事务也会失效,这里可以去查看《SpringBoot事务失效的原因》得到结论,本博客只做简单的解决方式。

? ? ? ? 如果手动捕获了异常,那么,在记录了异常日志以及接口调用情况时,可以手动在catch中抛出此异常,那么全局异常处理器和事务就会正常生效。

//定义环绕通知 增强打上AutoLog注解的类中所有方法
@Aroud(value = "AutoLog()")
public Object AutoLogAround(ProceedingJoinPoint proceedingJoinPoint){
    try{
        //前置通知
        //执行被增强的方法
        Object proceed = proceedingJoinPoint.proceed();
        //后置通知
    }catch(Exception e){
        //异常通知
        log.error("接口调用异常,原因:{}",e.getMessage());
        //手动抛出自定义的异常
        BaseException.businessRunTimeException(e);
    }finally{
        //最终通知
    }
}

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-09-24 20:42:45  更:2022-09-24 20:46:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:07:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码