notempty注解属于哪个依赖_厉害了!老大利用AOP实现自定义注解,半小时完成我三天工作量…

  • Post author:
  • Post category:其他


e4b61e1efcb3db2fba793f9b1ca3b821.png

整理自公众号:程序员闪充宝

来源:
http://
toutiao.com/i6795903732
807631363

前面我们已经介绍了AOP适用的一些业务场景以及简单的代码实现,当时我们的切点是用execution表达式来配置的,这种方式有一些局限性在里面:

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

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

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

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

d415970402bde5e21d8a65eec156e389.png

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

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

添加依赖

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

d8fd04995a54b6d4cc9860fc8f839769.png

自定义一个注解

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

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

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

配置AOP切面

首先我们定义切点:

4a1895b39c68b83d8326e1a44037a1c5.png

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

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

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

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

怎么使用自定义注解?

修饰Controller里的接口方法:

ddb2227a5085b0b0ebfa9f9bb8ed284f.png

修饰Service里的方法:

9ca128f1aa0b3788f3176c233fe47822.png

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

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

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

总结

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



版权声明:本文为weixin_30823465原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。