厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

前面我们已经介绍了AOP适用的一些业务场景以及简单的代码实现,当时我们的切点是用execution

表达式来配置的,这种方式有一些局限性在里面:

  • 灵活性不高,一个表达式只能切到某种同类型的方法
  • 个性化不足,很难对切面切到的所有方法中的一些做一些个性化的设置

这让我想起有以前我还是一个菜鸟时接到的一个需求,要在所有接口中记录请求日志,因为项目比较老了,所以接口还是挺多的,我预估需要三天才能完成,我们老大鄙视了我一眼,然后花半小时就完成了。

今天我们就来讲讲切点的另一种配置方式:@annotation,通过@annotation配置切点,我们可以灵活的控制切到哪个方法,同时可以进行一些个性化的设置,今天我们就用它来实现一个记录所有接口请求功能吧。

首先来看看我们要实现的效果

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

通过结果我们可以看到,我们的自定义注解EagleEye做到了统一的记录下了请求链接、请求类型、请求IP、请求入参、请求耗时、请求返回等信息。

是不是感觉还不错呢?下面我们就来一起动手实现它吧!

添加依赖

新建一个Spring Boot项目,打开pom.xml文件添加相关Maven依赖:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

自定义一个注解

我们定义了一个注解,定义注解使用@interface:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

  1. 定义了注解的生命周期为运行时
  2. 定义了注解的作用域为方法
  3. 标识该注解可以被JavaDoc记录
  4. 定义注解名称为EagleEye(鹰眼,哈哈~~)
  5. 定义一个元素desc,用来描述被修饰的方法

注解虽然定义好了,但是还用不了,因为没有具体的实现逻辑,接下来我们用AOP实现它。

配置AOP切面

首先我们定义切点:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

我们通过@annotation来配置切点,代表我们的AOP切面会切到所有用EagleEye注解修饰的类。

接下来我们利用@Around环绕增强来实现我们的功能:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

  1. 首先我们先记录请求链接、接口描述、请求类型、请求IP、请求入参信息
  2. 接着执行我们注解切到的原方法逻辑
  3. 最后我们记录整个请求耗时、返回结果

OK,到这里,我们就完成了利用AOP自定义注解的所有步骤。

怎么使用自定义注解?

修饰Controller里的接口方法:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

修饰Service里的方法:

厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量

对于需要AOP增强的方法,我们只需要:

  1. 在方法上加上@EagleEye注解
  2. 通过desc元素设置方法的描述

接下来启动应用,请求接口看一下控制台输出是不是像我们开头贴出的那样吧。

总结

当然,这仅仅是自定义注解的一种小用法而已,其他比如实现接口的自动加解密、权限过滤等更多实用功能,都会出现在后面的文章中。


分享到:


相關文章: