iReport5.6 生成PDF, 中英文混排时出现的问题

最近的物流供应链IT项目中遇到这么一个烦人的问题:使用ireport5.6生成PDF时,当一段文字中有使用中英文时,在浏览器中英文字体排列不规则的问题。注意,下文中所提到字体显示有问题,均指中英文字体混排时,英文字体显示有问题。

此问题应该有不少人会遇到,也为了帮助广大PDF中文使用者不用再承受解决此问题的痛苦,特将测试环境,解决思路及最终解决方案记录于此。事实上,我开始写的时候仍未解决,但我相信随着排查进度的深入,问题最终可以解决(结果也是如此)。

这里提笔开始写文章也是为了给公司的小伙伴展示解决问题的思路,我觉得,解决问题最重要的事情是:要有正确的思路。而我即将展示我的探索过程。

本文按环节分以下5部分:

1. 问题描述

2. ireport的设置,

3. 生成PDF的服务器

4. 对显示字体的调查

5. 最终解决方案:字体配置及打包

1. 问题描述

为说明问题,先上对比图,这是一张海运HBL的PDF(物流行业的文档)

Mac电脑上Chrome浏览器的效果图,一切都还OK


Win10上的chrome的效果图,英文字母的排列出现了严重错位

我对该问题进行了更多的双系统对比(用不同浏览器打开此PDF):

Mac:Chrome,Firefox,Safari中英文混排皆可正常显示

Win10:Chrome中英文混排效果很差,Firefox,Edge中英文混排效果略好于chrome,仍参差不齐

Win7:Chrome,Firefox中英文混排效果皆很差,IE11中英文混排效果略好

结论:如果用户使用Mac系统去操作就万事大吉,如果用户使用WIN系统,呵呵。。。

2. iReport对中英文字段的设置

通过第1点的工作,我决定将解决方向定位为:如何解决在Win系统下的显示中英文这个重点上,先来看看iReport中对此字体的设置

iReport中的字段设置

3. 生成PDF的服务器

服务器为CentOS,所以PDF的源头是一样,就是说,同样的PDF文件,在不同的系统中,不同的浏览器显示的中英文混排效果不同,所以我怀疑:

1. WIN系统的浏览器对PDF中文字体中的英文字体(样式)的预览有问题(bug)

2. iReport 的PDF的中文字体设置后,对混在其中的英文字体(样式)在WIN系统中的字体库中不存在,导致显示问题

由此我进入下一个调查重点:字体

4. 对显示字体的调查

为了研究字体的显示问题,我在Win系统中发现,如果使用Foxit PDF reader打开来预览文件的话,英文字体显示有问题; 而用Adober Reader打开后英文字体显示则没有问题,看图:


Adobe和Foxit两个reader所用的字体

嗯?为什么我的设置在不同的Reader中用了不同字体?我设置的样式应该是黑体才对啊,就是说“黑体”的字体没有找到,不同的PDF viewer在找不到对应的字体后,自动用其默认的字体去渲染显示,导致英文字体显示不正确。

字体设置

带着疑问,我开始了新的探索,尝试在网上找了相当多的文档,包括IReport官方文档,中文设置文档等等,然后开始了漫长的字体调试过程:导出字体并让服务器使用“黑体”


导入&导出“黑体”

把文件放到服务器,重启,一打印,就遇到 UniGB-UCS2-H编码问题

UniGB-UCS2-H编码问题

然后我认为“黑体”jar包已经装载了,尝试着把中文编码的三个必选项去掉,把重新编译好的Jasper文件放到服务器上,打印还是报错!于是开始基于UniGB-UCS2-H编码 去网上寻找相关文章,大概翻阅了几十篇后,果然被我找到了!!

iReport增加中文字体

这篇文章只是介绍了如何导出导入中文字体,却帮助了我解决了想要解决的问题,关键点在那中文三项配置里,Pdf Encoding一定要选Identity-H (Unicode with horizontal writing),而不是大多数网上文章说的 UniGB-UCS2-H (Chinese Simplified),否则一定会引发UniGB-UCS2-H编码问题!


Pdf Encoding一定要选Identity-H (Unicode with horizontal writing)

5. 最终解决方案:进行正确的字体配置及打包

在按照第4点中讲的方法,把PDF 模板所有中文字段都做了相应改动:Pdf Encoding选Identity-H (Unicode with horizontal writing),调试,一切都OK了!


Win10各个浏览器都显示正常

再次用不同PDF Reader打开查看字体,验证字体装载正确。


Adobe和Foxit两个reader所用的字体

结论:iReport编辑器字段设置问题->中文字体装载问题

在调查的过程中,我一度认为是否是浏览器的bug引起的,后来经过排查,最终确认了这个是我们使用iReport时的字段设置中文字体引起的问题,导致了中英文混排出现显示问题。

学海无涯,在学习的道路上,你并不孤单,希望本文可以帮助到相关的人,我是物流IT人,刘宇,谢谢,再见。


补充一个文章,有个朋友看到的亚马逊的PDF也有同样的问题,我也记录了一下:

iReport5.6 生成PDF, 中英文混排时出现的问题(亚马逊篇)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容