若依验证码渲染失效问题

Linux 服务器 Java 字体渲染异常排查记录:

在一次服务器环境迁移中,我遇到了一个看似简单、但排查起来颇为曲折的字体渲染问题。以下是完整的排查记录,希望能为同样在服务器上处理图片文字渲染的同学提供借鉴。

一、问题现象

验证码渲染失效,用的若依的框架。用的谷歌com.google.code.kaptcha生产的验证码

Java 程序在本地渲染图片文字一切正常,但部署到 Linux 服务器后出现异常:

  • 验证码串不显示,图片是空的 日志也没有任何报错

二、第一步:检查服务器字体

使用 Fontconfig 工具查看系统已有字体:

复制代码
fc-list

输出显示系统原本只有 Cantarell 字体:

ini 复制代码
/usr/share/fonts/abattis-cantarell-fonts/Cantarell-VF.otf: Cantarell:style=Regular

没有 Arial、Courier,也没有常用的开源字体(DejaVu / Liberation / DroidSans)。

三、进一步验证:强制指定 Cantarell 字体仍然不生效

在代码中强制:

arduino 复制代码
new Font("Cantarell", Font.PLAIN, 16)

仍然无法渲染出文字。

VF(Variable Font)在 Java 中支持确实不好

  • **Java AWT/Swing 的 FontRenderContext / GlyphVector 对可变字体(Variable Font, .VF, .otf variable)支持非常有限

  • 大多数情况下只能识别 VF 字体为"单一风格",无法正确处理权重、字形轴

  • 甚至会出现:

    • 宽度计算为 0
    • GlyphVector 渲染失败
    • drawString 不显示
    • fallback 失败

四、安装更通用的字体:DejaVu

Linux 中最稳妥的通用字体是 DejaVu(Java 100% 兼容)。

安装:

复制代码
yum install -y dejavu-sans-fonts

fc-cache -fv

再次查看字体列表:

复制代码
fc-list

此时字体库已经丰富:

复制代码
DejaVu Sans
DejaVu Serif
DejaVu Sans Mono
...

八、总结

本次问题的根因是:

服务器字体缺失

解决路径如下:

  1. fc-list 查看系统字体
  2. 发现服务器字体极少,而且都是vf字体
  3. 安装 DejaVu 字体
  4. 渲染恢复正常

这是 Linux 环境下 Java 图片文字渲染最典型、也最容易忽略的问题之一。

相关推荐
代码游侠3 分钟前
学习笔记——Linux字符设备驱动
linux·运维·arm开发·嵌入式硬件·学习·架构
1104.北光c°4 分钟前
【黑马点评项目笔记 | 优惠券秒杀篇】构建高并发秒杀系统
java·开发语言·数据库·redis·笔记·spring·nosql
ruleslol7 分钟前
普通流(Stream<T>)和原始类型特化流(IntStream, LongStream, DoubleStream)的区别
java
隐退山林7 分钟前
JavaEE初阶:文件操作和IO
java·java-ee
2501_907136828 分钟前
PDF增效工具 Quite imposing plus6
java·开发语言
Trouvaille ~10 分钟前
【Linux】UDP Socket编程实战(三):多线程聊天室与线程安全
linux·服务器·网络·c++·安全·udp·socket
Jaxson Lin11 分钟前
Java编程进阶:智能仿真无人机项目3.0
java·笔记·无人机
是阿楷啊13 分钟前
Java求职面试实录:互联网大厂场景技术点解析
java·redis·websocket·spring·互联网·大厂面试·支付系统
sagima_sdu19 分钟前
bin、sbin 与 usr/bin、usr/sbin 目录的区别和由来
linux·运维·网络
_周游21 分钟前
Java8 API文档搜索引擎_3.搜索模块(实现细节)
java·搜索引擎·intellij-idea