Spring Boot全局异常处理器返回400,但被WebFlux客户端调用时Filter仍返回500

Spring Boot全局异常处理器返回400,但被WebFlux客户端调用时Filter仍返回500

1. 系统环境

  • 框架: Spring Boot REST API(基于servlet)。

  • 全局异常处理器:

  • 使用@RestControllerAdvice捕获MyOperationException

  • 返回带有HTTP 400和自定义错误体的ResponseEntity

  • 强制Filter:
  • RuleVerifierFilter(无法修改,来自其他团队)。

  • 用try-catch包裹整个filter chain,任何异常都会设置响应为500。

2. 正常异常处理流程

  • MyService.downloadByKey抛出MyOperationException时,会被全局异常处理器捕获。

  • 处理器会记录异常日志并返回预期的ResponseEntity

  • 对于大多数客户端(如Postman、RestTemplate),表现正常:

  • 客户端收到带有HTTP 400的自定义错误响应。

3. 问题场景

  • 触发条件: 只有当上游团队用WebFlux(reactive)客户端调用API时才会出现。

  • 实际表现:

  • 全局异常处理器返回后,异常依然被RuleVerifierFilter捕获。

  • 客户端收到500错误,而不是预期的400。

  • 响应体内容如下:

{"error": "Request processing failed; nested exception is com.mycompany.myproject.exception.exceptions.MyOperationException"}

  • 连接没有被提前关闭,客户端能收到完整响应体。

4. 日志证据

  • 日志中显示有NestedServletException包裹了MyOperationException

  • 堆栈信息中既有controller也有RuleVerifierFilter

  • 说明异常在处理器之后仍然向上传递,被filter捕获。

5. 已尝试的排查步骤

  • 已确认全局异常处理器被调用并正确构建了响应。

  • 已验证只有WebFlux客户端会复现,其他客户端无法复现。

  • 本地尝试复现未成功。

6. 仍有疑问

  • 为什么异常在被全局异常处理器处理后还会传递到filter?

  • 使用WebFlux(reactive)客户端调用servlet API会导致这种现象吗?

  • 为什么只有WebFlux客户端会出现这个问题?

  • 如何确保异常被处理后不会再向上传递到filter?

  • 还有哪些排查方向或调试建议?

相关推荐
tb_first2 小时前
万字超详细苍穹外卖学习笔记3
java·jvm·笔记·学习·spring·tomcat·maven
CodeToGym2 小时前
【全栈进阶】Spring Boot 整合 WebSocket 实战:从实时告警到金融行情推送
java·后端·spring
Vivienne_ChenW2 小时前
Spring 事件驱动用法总结
java·开发语言·spring boot·spring
Rainly20002 小时前
java原生实现企业级spring batch数据迁移
java·spring·batch
1candobetter3 小时前
JAVA后端开发——Maven 依赖传递 ≠ Spring 自动装配
java·spring·maven
若鱼19193 小时前
SpringBoot4.0新特性-Null-safety消灭空指针
java·spring
1104.北光c°3 小时前
【黑马点评项目笔记 | 商户查询缓存篇】基于Redis解决缓存穿透、雪崩、击穿三剑客
java·开发语言·数据库·redis·笔记·spring·缓存
计算机学姐4 小时前
基于SpringBoot的校园流浪动物救助平台
java·spring boot·后端·spring·java-ee·tomcat·intellij-idea
玄〤4 小时前
SpringCloud微服务用户身份拦截器配置详细解决方案(黑马商城)(springcloud微服务课day6)
spring·spring cloud·微服务
那我掉的头发算什么4 小时前
【Mybatis】动态SQL与留言板小项目
数据库·spring boot·sql·spring·mybatis·配置