当前位置: 首页 > ops >正文

Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决

Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决

问题背景

在一个基于 Spring Cloud Gateway + WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 CircleCaptcha 生成验证码图片。然而在部署上线后,访问该接口始终返回 404,而其他网关转发接口均正常。

该接口定义如下:

@Configuration
public class RouterFunctionConfiguration {@Autowiredprivate ValidateCodeHandler validateCodeHandler;@Beanpublic RouterFunction<?> routerFunction() {return RouterFunctions.route(RequestPredicates.GET("/code").and(RequestPredicates.accept(MediaType.TEXT_PLAIN)),validateCodeHandler);}
}

初步排查思路

起初怀疑为以下常见问题:

  1. Accept: text/plain 请求头不匹配;
  2. 路由被 gateway.routes/code/** 路由转发覆盖;
  3. RouterFunction Bean 未生效或未注入;
  4. ValidateCodeHandler 写法错误;
  5. 实际监听端口与预期不符(注册到 Nacos 的端口为 8080)。

经多项验证后发现,这些都不是直接原因


真正的原因:JVM 图形字体系统缺失导致验证码生成失败

查看日志后,发现关键错误如下:

java.lang.NoClassDefFoundError: Could not initialize class sun.font.SunFontManagerat sun.font.FontDesignMetrics.getMetrics(FontDesignMetrics.java:264)...at cn.hutool.captcha.CircleCaptcha.createImage(...)

Hutool 的 CircleCaptcha 使用 Java AWT 图形库渲染验证码,而 AWT 依赖系统字体和图形环境支持。在当前使用的 Docker 镜像 openjdk:8-jre-slim 中,字体系统缺失,导致:

  • JVM 无法初始化字体管理器;
  • Captcha.createImage() 方法抛出 NoClassDefFoundError
  • WebFlux 返回 500,但表现为 /code 接口 404(无默认异常处理器);
  • 外部看起来像是“接口路由失效”。

解决方案

方案一:更换基础镜像(推荐)

将 Dockerfile 中基础镜像改为完整版本:

FROM openjdk:8-jre  # 或 openjdk:8-jdk

该版本包含 AWT 和字体支持,开箱即用。


方案二:在 slim 镜像中安装字体依赖

如果仍想使用 slim 镜像,可在构建中添加字体:

RUN apt-get update && apt-get install -y fontconfig ttf-dejavu

或者更小:

RUN apt-get update && apt-get install -y fonts-dejavu-core

这会安装 JVM 字体渲染所需的核心字体文件和环境。


方案三:替换验证码实现逻辑

如果无需图形验证码,可以:

  • 改用字符验证码;
  • 替换为不依赖 AWT 的实现;
  • 或直接生成文本验证码。

验证建议

1. 使用 curl 添加请求头进行测试:

curl -H "Accept: text/plain" http://localhost:8001/code

2. 日志开启 Web 路由匹配调试:

logging:level:org.springframework.web: DEBUG

总结

问题原因
/code 接口 404实际是内部抛出 NoClassDefFoundError,未进入 handler
报错类sun.font.SunFontManager 无法初始化
根本原因Docker 镜像缺少字体渲染环境
解决方式更换镜像或安装字体

建议

在使用 Hutool、Captcha、或任何基于 AWT 的组件时,务必检查部署环境是否具备必要图形支持。特别是在 Docker 化部署中,openjdk-slim 镜像虽小,但常缺关键功能,适用场景需慎重评估。

在这里插入图片描述

http://www.xdnf.cn/news/12082.html

相关文章:

  • 基于BI PaaS架构的衡石HENGSHI SENSE平台技术解析:重塑企业级数据分析基座
  • 猎板厚铜PCB工艺能力如何?
  • Web 架构相关文章目录(持续更新中)
  • Jenkins | Linux环境部署Jenkins与部署java项目
  • select、poll、epoll 与 Reactor 模式
  • 70年使用权的IntelliJ IDEA Ultimate安装教程
  • 代码中文抽取工具并替换工具(以ts为例)
  • 数据结构:泰勒展开式:霍纳法则(Horner‘s Rule)
  • DeepSeek-R1-0528-Qwen3-8B为底座微调领域大模型准备:制作领域专用数据集
  • HarmonyOS:Counter计数器组件
  • QQ邮箱发送验证码(Springboot)
  • AI系统负载均衡与动态路由
  • 力扣HOT100之二分查找: 34. 在排序数组中查找元素的第一个和最后一个位置
  • 数学建模-嘉陵江铊污染事件解题全过程文档及程序
  • 联软NSPM自动化策略管理 助力上交所加速国产化替代提升运维效率
  • matlab实现DBR激光器计算
  • 全维度测试通过!DolphinScheduler 3.2.0单节点部署与验证实录
  • cursor-free-vip使用
  • [实际项目2] 从西门子PLC中读取曲线数值并绘图
  • 半监督学习:低密度分离假设 (Low-Density Separation Assumption)
  • IT组织转型记:从运维支持到数字利润中心的蜕变
  • OpenCV CUDA模块图像处理-----对图像执行 均值漂移过程(Mean Shift Procedure)函数meanShiftProc()
  • opencv学习笔记1:图像基础、图像操作、直方图均衡化详解
  • 破局新能源消纳难题!安科瑞智慧能源平台助力10KV配电网重构未来
  • Python数据可视化科技图表绘制系列教程(三)
  • AtCoder-abc408_b 解析
  • React hook之userReducer
  • vue-19(Vuex异步操作和变更)
  • 【android bluetooth 协议分析 02】【bluetooth hal 层详解 7】【高通蓝牙hal-读流程介绍】
  • 古老界面硬核工具:小兵以太网测试仪(可肆意组包,打vlan)