spring boot 实现一个 禁止重复请求

在Spring Boot中,实现禁止重复请求可以通过以下步骤:

1.添加依赖 首先,需要添加Spring Boot的Web依赖,在pom.xml文件中添加以下依赖:

xml 复制代码
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>

2.创建自定义注解 创建一个自定义的注解,用于标注需要进行重复请求限制的方法。可以通过@Retention(RetentionPolicy.RUNTIME)注解来指定注解的保留策略。

java 复制代码
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface NoRepeatRequest {
}

3.编写拦截器 创建一个拦截器,用于拦截标有@NoRepeatRequest注解的方法。在拦截器中可以使用一个容器来存储已处理的请求,比如使用ConcurrentHashMap。

java 复制代码
@Component
public class NoRepeatRequestInterceptor implements HandlerInterceptor {

   private Map<String, Object> requestMap = new ConcurrentHashMap<>();

   @Override
   public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
       // 获取请求的URL和方法名
       String url = request.getRequestURL().toString();
       String method = request.getMethod();

       // 生成请求的唯一标识
       String key = url + "_" + method;

       // 如果容器中已存在该请求,则表示是重复请求
       if (requestMap.containsKey(key)) {
           response.getWriter().write("Duplicate request");
           return false;
       }

       // 将请求添加到容器中
       requestMap.put(key, new Object());
       return true;
   }

   @Override
   public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
       // 请求处理完毕后,从容器中移除该请求
       String url = request.getRequestURL().toString();
       String method = request.getMethod();
       String key = url + "_" + method;
       requestMap.remove(key);
   }
}

4.注册拦截器 在配置类中注册拦截器,并将其应用于需要进行重复请求限制的方法。

java 复制代码
@Configuration
public class WebConfig implements WebMvcConfigurer {

   @Autowired
   private NoRepeatRequestInterceptor noRepeatRequestInterceptor;

   @Override
   public void addInterceptors(InterceptorRegistry registry) {
       registry.addInterceptor(noRepeatRequestInterceptor)
               .addPathPatterns("/**")  // 可以根据具体的URL进行配置
               .excludePathPatterns("/error");  // 排除错误页面的拦截
   }
}

现在,只需要在需要进行重复请求限制的方法上添加@NoRepeatRequest注解即可。

java 复制代码
@Controller
public class TestController {

   @NoRepeatRequest
   @RequestMapping("/test")
   @ResponseBody
   public String test() {
       // 处理业务逻辑
       return "success";
   }
}

这样,当重复请求该方法时,会返回"Duplicate request",避免重复执行相同的操作。

以上就是使用Spring Boot实现禁止重复请求的方法。通过自定义注解、拦截器和容器,可以实现对重复请求的限制。

相关推荐
xxjj998a8 小时前
spring security 超详细使用教程(接入springboot、前后端分离)
java·spring boot·spring
weixin_408099678 小时前
OCR 在线识别 + API 接口实战:从网页验证到系统集成
图像处理·人工智能·后端·ocr·api·图片文字识别·文字识别
crack_comet8 小时前
Spring Boot 3.5.11 分离打包(无参数启动+Jar瘦身)完整配置文档
java·spring boot·后端·maven·intellij-idea·jar
echome8888 小时前
Go 语言并发编程:Channel 与 Goroutine 的完美结合
开发语言·后端·golang
weixin_408099678 小时前
身份证正反面合并+识别OCR接口调用
java·人工智能·后端·python·ocr·api·身份证ocr
橘子编程9 小时前
Django全栈开发终极指南
后端·python·django·npm·html·pandas·html5
Java成神之路-9 小时前
Spring 注解开发进阶实战:Bean 生命周期、 依赖注入及Properties配置(Spring系列4)
java·后端·spring
牛奔9 小时前
升级Go 版本,导致兼容性依赖编译错误排查并解决
开发语言·后端·golang
小邓的技术笔记9 小时前
聊聊 ASP.NET Core 中间件和过滤器的区别
后端·中间件·asp.net
运维行者_9 小时前
网络监控告警设置指南:如何配置智能告警规避“告警风暴”?
linux·运维·服务器·网络·后端