iText 7 支持匈牙利语特殊字符显示方法
时间:2026-02-26 22:06:48 331浏览 收藏
在 iText 7 中正确渲染匈牙利语特殊字符(如ő、ű、Ő、Ű)的关键在于摒弃默认的UTF-8编码和StandardFonts,转而使用支持东欧语言的CP1250编码(Windows Latin-2标准)、本地TrueType字体文件(如arial.ttf)并强制嵌入字体——这一组合精准覆盖U+0151、U+0171等码位,彻底解决空白或方块乱码问题,同时兼顾轻量性与跨平台可靠性,是生成符合匈牙利语排版规范PDF的最简高效方案。

在 iText 7 中使用系统字体(如 Arial 或 Times New Roman)渲染匈牙利语等东欧语言的 Unicode 字符时,若直接指定 `PdfEncodings.UTF8` 仍显示为空白,应改用兼容的 Windows 字符编码 `CP1250` 并嵌入字体,才能正确显示 ő、ű、Ő、Ű 等字符。
iText 7 默认的 StandardFonts(如 TIMES_BOLD)仅包含基础 Latin-1 字符集(ISO-8859-1),不支持扩展拉丁字符(如带双重重音的 ő/ű)。即使这些字符在操作系统字体中存在,若未显式指定兼容编码并嵌入字体,PDF 渲染引擎将无法映射字形,最终输出为空白或方块。
✅ 正确做法是:使用本地 TrueType 字体文件(如 arial.ttf 或 times.ttf),配合 CP1250 编码(Windows Latin-2,专为中/东欧语言设计),并启用字体嵌入(true 参数):
// ✅ 推荐:使用 CP1250 编码 + 嵌入字体(关键!)
PdfFont font = PdfFontFactory.createFont(
"C:/Windows/Fonts/arial.ttf", // Windows 路径;Linux/macOS 请替换为 /usr/share/fonts/truetype/dejavu/DejaVuSans.ttf 等
PdfEncodings.CP1250, // 不是 UTF8!CP1250 显式支持 ő, ű, Ő, Ű
true // 必须设为 true,确保字体嵌入 PDF,避免目标环境缺失字体
);⚠️ 注意事项:
- PdfEncodings.UTF8 在 iText 7 中不适用于字体编码映射——它仅用于字符串解码,而字体本身需通过 createFont(..., encoding, embedded) 的 encoding 参数声明其字符集范围。CP1250 是 Windows 下匈牙利语、波兰语、捷克语等的标准编码,原生覆盖 U+0151 (ő)、U+0171 (ű) 等码位。
- 若使用 StandardFonts.TIMES_BOLD,其底层为 Type 1 字体,不支持 Unicode 扩展字符,且无法指定编码,故必须弃用,改用本地 TTF 文件。
- 字体路径需真实存在,且应用有读取权限;生产环境建议将字体文件打包进 resources,用 getClass().getResourceAsStream("/fonts/arial.ttf") 加载,提升可移植性。
- 中文、日文等其他 Unicode 字符需改用 Identity-H 编码(配合 Noto Sans CJK 等字体),但 CP1250 对匈牙利语已足够且更轻量。
最后,整合到你的 addCenteredParagraph 方法中:
private static void addCenteredParagraph(Document document, float width, String text) {
PdfFont font = null;
try {
// 使用 CP1250 + 嵌入字体(推荐 Arial 或 Times New Roman 的 .ttf)
font = PdfFontFactory.createFont("C:/Windows/Fonts/arial.ttf", PdfEncodings.CP1250, true);
} catch (IOException e) {
LOGGER.error("Failed to load font with CP1250 encoding", e);
return;
}
List<TabStop> tabStops = new ArrayList<>();
tabStops.add(new TabStop(width / 2, TabAlignment.CENTER));
tabStops.add(new TabStop(width, TabAlignment.LEFT));
Paragraph p = new Paragraph()
.addTabStops(tabStops)
.setFontSize(14)
.setFont(font)
.setTextAlignment(TextAlignment.CENTER); // 更直观的居中方式(替代 Tab)
p.add(text); // 直接添加文本,无需手动加 Tab(除非需复杂对齐)
document.add(p);
}✅ 总结:解决 ő/ű 显示问题的核心不是“UTF-8”,而是选择支持该字符集的字体 + 匹配的编码(CP1250)+ 强制嵌入。跳过 StandardFonts,拥抱本地 TTF 与 CP1250,即可稳定输出符合匈牙利语排版规范的 PDF。
今天关于《iText 7 支持匈牙利语特殊字符显示方法》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
316 收藏
-
492 收藏
-
125 收藏
-
120 收藏
-
116 收藏
-
188 收藏
-
285 收藏
-
323 收藏
-
490 收藏
-
263 收藏
-
421 收藏
-
178 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习