需求背景:
因为一些比如退单之类的接口处理流程没有做幂等性校验,只有接口开头有一个检验同一笔订单请求挂起一秒钟,所以在接口处理流程阻塞状态下,多笔请求进来的时候就造成了幂等性的问题,以我自己的思维模式考虑的话,首先是前端需要加上校验,后端接口在最小影响范围内的话是把1秒时间扩大,但是领导是个有技术追求的人,所以提出了自定义一个防并发注解
自定义注解
在Java中,注解分为两种,元注解和自定义注解。
很多人误以为自定义注解就是开发者自己定义的,而其它框架提供的不算,其实我们经常会用到的一些如@Override、@Autowired、@Service等,这些都是JDK或者诸如Spring这类框架给我们提供的,都属于自定义注解。
关于"元"这个描述,在编程世界里面有都很多,比如"元注解"、"元数据"、"元类"、"元表"等等,这里的"元"其实都是从meta翻译过来的。
一般我们把元注解理解为描述注解的注解,元数据理解为描述数据的数据,元类理解为描述类的类…
所以,在Java中,除了有限的几个固定的"描述注解的注解"以外,所有的注解都是自定义注解。
在JDK中提供了4个标准的用来对注解类型进行注解的注解类(元注解),他们分别是:
@Target
@Retention
@Documented
@Inherited
除了以上这四个,所有的其它注解全部都是自定义注解。
那么我这次做的这个自定义注解是用apring的AOP实现的,因为保密协议和知识产权原因,以下代码经过加工
首先先自定义一个注解
然后就就是注解的实现类:
首先定义一个切点
然后定义一个环绕类型的切面实现
具体代码就不展示了,主要逻辑是,注解参数组成一个唯一的key,放到缓存里面,下次请求进来,如果缓存还存在就中断流程,返回重复提交巴拉巴拉的内容,如果不存在就set到缓存里面,使用 joinPoint.proceed() 继续执行被注解方法,然后在finally里面强制释放缓存
注意如果是springBoot,只需要在注解实现类上加上@Aspect 和 @Component注解就好,如果是springMvc的话,并且是在controller层使用的话,需要手动把生成管理交给springMVC容器
具体使用方法:
#user.name 使用el表达式获取参数列表指定的参数,注解之内还有解析方法,具体可以参考 https://mp.csdn.net/mp_blog/creation/editor/118080404