您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

一个注解实现接口幂等,这样才优雅!

时间:2023-08-01 05:20:30  来源:微信公众号  作者:码猿技术专栏
本节内容介绍了防重注解@RepeatSubmit的实现原理,后续开发中只需要在非查询接口中添加这个注解就能保证在一定时间内防止重复提交。

场景

码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:

图片图片

上述代码有问题吗?谁能说有问题?一般情况下是没什么问题,但是在高并发的场景下肯定是存在问题,为什么?

因为有事务的隔离性,step1这个阶段对住院号的校验肯定是存在问题的,在高并发的场景下无法保证这里的校验一定准确。

其实这个接口的并发并不高,在码猿慢病云管理系统中一般不会出现这种问题,那么什么时候会出现呢?

医院中大部分是内网+外网,如果由于网络的抖动,系统请求响应的时间延迟,这样会导致医护操作时会出现重复点击的情况,比如1秒中之内由于第一次点添加患者这个按钮没反应,往往护士都会重复点击,这种情况下是会出现问题。

这里我们就暂且不谈对单个接口的幂等优化了,要想一个方案全局解决这个问题,在码猿慢病云管理系统中其实只要保证这种并发不高的接口在一定时间段内保证幂等即可,比如5秒之内,这样在5秒之内护士重复点击就没事。

解决方案

在码猿慢病云管理系统中新增了一个注解:@RepeatSubmit,代码如下:

图片图片

只需要将该注解标注在新增、修改、删除接口上就能保证在默认的5秒之内接口幂等。

比如新增住院患者这个接口:

图片图片

那么原理是什么?其实很简单,先来说下原理,再介绍具体的实现:

  1. AOP拦截增强@RepeatSubmit注解
  2. 获取请求的URL、IP地址、请求参数
  3. 将请求URL、IP地址、请求参数以一定形式转为key
  4. 借助redis的setNx命令将key存入Redis,且设置失效时间
  5. 如果存入成功则允许访问,失败则抛出异常
  6. 全局异常捕获,输出指定信息给客户端

上述6个步骤中其实只有一点比较难实现的,其他的都是基本操作,就是获取这个请求参数,下面将详细介绍一下如何获取这个请求参数。

获取请求参数

对于form-data的入参只需要调用HttpServletRequest的API读取,但是对于@RequestBody标注的入参是通过IO流读取数据,且IO流只能被读取一次,如果在AOP中读取了,那么在接口层面的入参读取肯定是有问题,报错如下:

图片图片

解决方案也很简单,只需要保证IO流能够多次读取即可,下面就来介绍一下方案。

这里我们可以利用装饰者模式对 HttpServletRequest 的功能进行增强,具体做法也很简单,我们重新定义一个 HttpServletRequest:

图片图片

图片图片

这段代码并不难,很好懂。

首先在构造 RepeatedlyRequestWrApper 的时候,就通过 IO 流将数据读取出来并存入到一个 byte 数组中,然后重写 getReader 和 getInputStream 方法,在这两个读取 IO 流的方法中,都从 byte 数组中返回 IO 流数据出来,这样就实现了反复读取了。

接下来我们定义一个过滤器,让这个装饰后的 Request 生效:

图片图片

判断一下,如果请求数据类型是 JSON 的话,就把 HttpServletRequest “偷梁换柱”改为 HttpRequestWrapper,然后让过滤器继续往下走。

这样就可以配置后就可以在程序中反复读取参数了!

防重注解实现

解决了参数读取的问题,下面就可以轻松实现这个防重注解了,首先定义注解com.code.ape.codeape.common.security.annotation.RepeatSubmit:

图片图片

接下来直接用AOP实现,com.code.ape.codeape.common.security.component.CodeapeRepeatSubmitAspect代码如下:

图片图片

图片图片

逻辑很简单,上述已经介绍过完整的流程,这里需要注意的是参数的读取,代码如下:

图片图片

其实就是将request判断下是否是经过过滤器封装后的HttpRequestWrapper对象,如果是的话则是@RequestBody入参,直接从IO流中读取。

总结

本节内容介绍了防重注解@RepeatSubmit的实现原理,后续开发中只需要在非查询接口中添加这个注解就能保证在一定时间内防止重复提交。

码猿慢病云管理系统已经在星球中陆续更新,目前更新内容如下:

前言
     01 项目架构+业务介绍
     02 三方组件介绍
     03 服务端项目部署
     04 前端项目部署
     05 多租户架构设计
     06 医疗系统中的权限如何设计?
     07 项目搭建
     08 关掉验证码登录
     09 开发平台自动生成业务代码
认证鉴权
     01 认证登录生成token
     02 token检验、鉴权
     03 token有效期设置
     04 刷新token
     05 检查token
     06 服务中如何获取当前登录用户信息?
     07 接口对外暴露
     08 接口只允许内部调用怎么处理?
     09 如何实现token中继?
     10 当前登录用户身份信息如何异步传递?
     11 科室权限如何定一个注解自动注入?
     12 一个注解防止接口重复提交
业务
     01 科室管理
     02 医院管理
     03 角色管理


Tags:注解   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
一段微信小程序前端与后端连接的代码,带注解
微信小程序的前端和后端连接通常涉及到使用微信小程序提供的网络请求API与后端服务器进行通信。以下是一个简单的示例,展示如何使用微信小程序的前端代码向后端发送请求并处...【详细内容】
2024-01-24  Search: 注解  点击:(55)  评论:(0)  加入收藏
Python Union联合类型注解:让你的代码更灵活多变!
在Python中,类型注解是一种用于指定变量、函数参数和返回值的类型的方法。它可以提供代码的可读性和可维护性,并帮助开发人员在编写代码时捕获潜在的类型错误。Python 3.5引入...【详细内容】
2023-12-06  Search: 注解  点击:(191)  评论:(0)  加入收藏
Java反射与注解:揭开类加载与运行时动态特性
Java是一种强大而灵活的编程语言,其提供了许多高级特性来增强程序的灵活性和可扩展性。其中,Java反射和注解是两个重要的特性,它们可以在运行时动态地操作和扩展Java程序。下面...【详细内容】
2023-11-16  Search: 注解  点击:(217)  评论:(0)  加入收藏
Spring Cache 缓存注解这样用,实在是太香了!
作者最近在开发公司项目时使用到 Redis 缓存,并在翻看前人代码时,看到了一种关于 @Cacheable 注解的自定义缓存有效期的解决方案,感觉比较实用,因此作者自己拓展完善了一番后分...【详细内容】
2023-11-09  Search: 注解  点击:(201)  评论:(0)  加入收藏
SpringBoot常用的50个注解,一目了然
我们在使用SpringBoot开发项目的时候,使用注解是最频繁和自然的事。这些注解让我们摆脱了繁琐的传统Spring XML配置,让我们开发项目更加高效和简单,springboot注解那么多,其实常...【详细内容】
2023-11-06  Search: 注解  点击:(207)  评论:(0)  加入收藏
SpringBoot的Cacheable缓存注解
当我们的应用程序需要频繁地读取和写入数据时,为了提高应用程序的性能,我们通常会使用缓存技术。Spring Boot 提供了一种简单而强大的缓存框架,它可以轻松地将数据缓存到 Redis...【详细内容】
2023-08-31  Search: 注解  点击:(270)  评论:(0)  加入收藏
SpringBoot通过一个注解结合Redis实现接口限流就是这么简单
接口限流是指在系统中对接口进行限制访问,以保护系统不被过载或异常流量所影响。这通常是为了防止DDoS攻击或其他类型的恶意流量攻击,以及确保系统的稳定性和可靠性。环境:Spri...【详细内容】
2023-08-21  Search: 注解  点击:(256)  评论:(0)  加入收藏
28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈
前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解...【详细内容】
2023-08-04  Search: 注解  点击:(316)  评论:(0)  加入收藏
一个注解实现接口幂等,这样才优雅!
本节内容介绍了防重注解@RepeatSubmit的实现原理,后续开发中只需要在非查询接口中添加这个注解就能保证在一定时间内防止重复提交。场景码猿慢病云管理系统中其实高并发的场...【详细内容】
2023-08-01  Search: 注解  点击:(512)  评论:(0)  加入收藏
SpringBoot自定义注解+AOP+redis实现防接口幂等性重复提交,从概念到实战
在Web开发中,我们经常需要防止用户重复提交某个操作,尤其是一些需要保证数据一致性的操作,如支付等。而接口幂等性就是解决这个问题的一种方案。接口幂等性指的是,无论调用多少...【详细内容】
2023-06-07  Search: 注解  点击:(215)  评论:(0)  加入收藏
▌简易百科推荐
即将过时的 5 种软件开发技能!
作者 | Eran Yahav编译 | 言征出品 | 51CTO技术栈(微信号:blog51cto) 时至今日,AI编码工具已经进化到足够强大了吗?这未必好回答,但从2023 年 Stack Overflow 上的调查数据来看,44%...【详细内容】
2024-04-03    51CTO  Tags:软件开发   点击:(5)  评论:(0)  加入收藏
跳转链接代码怎么写?
在网页开发中,跳转链接是一项常见的功能。然而,对于非技术人员来说,编写跳转链接代码可能会显得有些困难。不用担心!我们可以借助外链平台来简化操作,即使没有编程经验,也能轻松实...【详细内容】
2024-03-27  蓝色天纪    Tags:跳转链接   点击:(12)  评论:(0)  加入收藏
中台亡了,问题到底出在哪里?
曾几何时,中台一度被当做“变革灵药”,嫁接在“前台作战单元”和“后台资源部门”之间,实现企业各业务线的“打通”和全域业务能力集成,提高开发和服务效率。但在中台如火如荼之...【详细内容】
2024-03-27  dbaplus社群    Tags:中台   点击:(8)  评论:(0)  加入收藏
员工写了个比删库更可怕的Bug!
想必大家都听说过删库跑路吧,我之前一直把它当一个段子来看。可万万没想到,就在昨天,我们公司的某位员工,竟然写了一个比删库更可怕的 Bug!给大家分享一下(不是公开处刑),希望朋友们...【详细内容】
2024-03-26  dbaplus社群    Tags:Bug   点击:(5)  评论:(0)  加入收藏
我们一起聊聊什么是正向代理和反向代理
从字面意思上看,代理就是代替处理的意思,一个对象有能力代替另一个对象处理某一件事。代理,这个词在我们的日常生活中也不陌生,比如在购物、旅游等场景中,我们经常会委托别人代替...【详细内容】
2024-03-26  萤火架构  微信公众号  Tags:正向代理   点击:(10)  评论:(0)  加入收藏
看一遍就理解:IO模型详解
前言大家好,我是程序员田螺。今天我们一起来学习IO模型。在本文开始前呢,先问问大家几个问题哈~什么是IO呢?什么是阻塞非阻塞IO?什么是同步异步IO?什么是IO多路复用?select/epoll...【详细内容】
2024-03-26  捡田螺的小男孩  微信公众号  Tags:IO模型   点击:(8)  评论:(0)  加入收藏
为什么都说 HashMap 是线程不安全的?
做Java开发的人,应该都用过 HashMap 这种集合。今天就和大家来聊聊,为什么 HashMap 是线程不安全的。1.HashMap 数据结构简单来说,HashMap 基于哈希表实现。它使用键的哈希码来...【详细内容】
2024-03-22  Java技术指北  微信公众号  Tags:HashMap   点击:(11)  评论:(0)  加入收藏
如何从头开始编写LoRA代码,这有一份教程
选自 lightning.ai作者:Sebastian Raschka机器之心编译编辑:陈萍作者表示:在各种有效的 LLM 微调方法中,LoRA 仍然是他的首选。LoRA(Low-Rank Adaptation)作为一种用于微调 LLM(大...【详细内容】
2024-03-21  机器之心Pro    Tags:LoRA   点击:(12)  评论:(0)  加入收藏
这样搭建日志中心,传统的ELK就扔了吧!
最近客户有个新需求,就是想查看网站的访问情况。由于网站没有做google的统计和百度的统计,所以访问情况,只能通过日志查看,通过脚本的形式给客户导出也不太实际,给客户写个简单的...【详细内容】
2024-03-20  dbaplus社群    Tags:日志   点击:(4)  评论:(0)  加入收藏
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  云原生散修  微信公众号  Tags:Kubernetes   点击:(6)  评论:(0)  加入收藏
站内最新
站内热门
站内头条