问题描述
我正在使用 Apache FOP(v 2.3 和测试 v 2.5)。我最近从 Oracle JDK 8 升级到了 Oracle JDK 11。我在 Oracle Linux(它是 RedHat 衍生产品)上使用 JBoss EAP 7.2。使用 JDK 8 时一切正常,但只是升级到 JDK 11 导致我的 FOP XSLT for XML -> PDF 和 XML -> PNG 创建以下堆栈跟踪(FOP 版本无关紧要,因为产生了相同的错误)。
Caused by: java.lang.NullPointerException
at java.desktop/sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1262)
at java.desktop/sun.awt.FontConfiguration.readFontConfigFile(FontConfiguration.java:225)
at java.desktop/sun.awt.FontConfiguration.init(FontConfiguration.java:107)
at java.desktop/sun.awt.X11FontManager.createFontConfiguration(X11FontManager.java:719)
我的字体是 Google/RedHat 的 LiberationSans,我已将它们放在文件系统中并在名为 LiberationSans.xconf 的文件中进行配置。我已确保文件可全局读取 (775) 并且归运行 JBoss 实例的用户所有。
<?xml version="1.0"?>
<!-- LiberationSans -->
<fop version="1.0">
<renderers>
<renderer mime="application/pdf">
<fonts>
<font embed-url="/apps/fonts/LiberationSans-Regular.ttf" embedding-mode="subset">
<font-triplet name="LiberationSans" style="normal" weight="normal"/>
</font>
<font embed-url="/apps/fonts/LiberationSans-Bold.ttf" embedding-mode="subset">
<font-triplet name="LiberationSans" style="normal" weight="bold"/>
</font>
</fonts>
</renderer>
<renderer mime="image/png">
<fonts>
<font embed-url="/apps/fonts/LiberationSans-Regular.ttf" embedding-mode="subset">
<font-triplet name="LiberationSans" style="normal" weight="normal"/>
</font>
<font embed-url="/apps/fonts/LiberationSans-Bold.ttf" kerning="yes" embedding-mode="subset">
<font-triplet name="LiberationSans" style="normal" weight="bold"/>
</font>
</fonts>
</renderer>
</renderers>
</fop>
在我的本地 Windows 机器上一切正常,但我的部署是通过 Eclipse/JBoss 插件进行的,所以可能会有一些问题。 Linux 服务器上的部署是通过 jboss-cli 进行的。
如果我能提供的其他任何东西可能有帮助,请告诉我。如果我们必须从 FOP 迁移,我希望这是最后的手段。
解决方法
结果不是我无法访问字体,而是 Linux 操作系统要求我通过 yum 安装 fontconfig。
yum install fontconfig
我不确定为什么 Oracle JDK 11 加上缺少的 Linux 实用程序是问题,因为这现在在我的生产环境中使用 Oracle JDK 1.8 并且没有安装 fontconfig。