Apache POI导出出现FontConfiguration中NULL

OpenJDK 比JDK缺少AWT组件部分功能

Apache POI 中使用SXSSFWorkbook出现Excel导出失败的异常。

问题堆栈

java 复制代码
java.lang.NullPointerException: null
        at sun.awt.FontConfiguration.getVersion(FontConfiguration.java:1264)
        at sun.awt.FontConfiguration.readFontConfigFile(FontConfiguration.java:219)
        at sun.awt.FontConfiguration.init(FontConfiguration.java:107)
        at sun.awt.X11FontManager.createFontConfiguration(X11FontManager.java:774)
        at sun.font.SunFontManager$2.run(SunFontManager.java:431)
        at java.security.AccessController.doPrivileged(Native Method)
        at sun.font.SunFontManager.<init>(SunFontManager.java:376)
        at sun.awt.FcFontManager.<init>(FcFontManager.java:35)
        at sun.awt.X11FontManager.<init>(X11FontManager.java:57)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
        at java.lang.Class.newInstance(Class.java:442)
        at sun.font.FontManagerFactory$1.run(FontManagerFactory.java:83)
        at java.security.AccessController.doPrivileged(Native Method)
        at sun.font.FontManagerFactory.getInstance(FontManagerFactory.java:74)
        at java.awt.Font.getFont2D(Font.java:491)
        at java.awt.Font.canDisplayUpTo(Font.java:2060)
        at java.awt.font.TextLayout.singleFont(TextLayout.java:470)
        at java.awt.font.TextLayout.<init>(TextLayout.java:531)
        at org.apache.poi.ss.util.SheetUtil.getDefaultCharWidth(SheetUtil.java:285)
        at org.apache.poi.xssf.streaming.AutoSizeColumnTracker.<init>(AutoSizeColumnTracker.java:117)
        at org.apache.poi.xssf.streaming.SXSSFSheet.<init>(SXSSFSheet.java:89)
        at org.apache.poi.xssf.streaming.SXSSFWorkbook.createAndRegisterSXSSFSheet(SXSSFWorkbook.java:701)
        at org.apache.poi.xssf.streaming.SXSSFWorkbook.createSheet(SXSSFWorkbook.java:722)

根本原因

服务器是使用的JDK是OpenJDK,AWT组件中被简化了,没有字体,同时服务器中没有字体包。而本地一般使用OracleJDK拥有完整的AWT功能。结果常出现本地服务功能正常,生产环境失败。

修复方案

方案一

直接将JDK更换成完整的版本,不用OpenJDK。

方案二

如果是使用Apache POI导出Excel失败,可以升级poi的jar版本,在5.2.3版本的时候对这个问题进行了修复。

https://poi.apache.org/changes.html#5.2.3

Type BUG Module Description
66230 SXSSF SXSSFWorkbook should work even when fonts not installed on OS

方案三

给服务器(CentOS)安装配置字体

  1. 安装fontconfig

    在线安装

    shell 复制代码
    yum install fontconfig

    离线方法,需要去下载对应的离线安装包,根据系统版本而定。举例:

    shell 复制代码
    rpm -ivh fontconfig-2.10.95-10.el7.x86_64.rpm  --nodeps --force
  2. 安装字体ttf-dejavu

    在线安装

    shell 复制代码
    yum install ttf-dejavu

    离线方法,需要去下载对应的离线安装包,根据系统版本而定。举例:

    下载地址:https://packages.msys2.org/packages/mingw-w64-x86_64-ttf-dejavu,取出其中的字体文件,重新打包

    上传字体:将 字体文件打包上传到服务器,解压到 /usr/share/fonts 目录

    刷新字体:执行命令fc-cache --force

    查看安装的字体:执行命令 fc-list

    在上述的方案操作之后都是重启项目。

相关推荐
运维全栈笔记10 小时前
Linux安装配置Tomcat保姆级教程:从部署到性能调优
linux·服务器·中间件·tomcat·apache·web
❀͜͡傀儡师19 小时前
Apache Doris 4.0.0 存算分离手动部署指南
apache·doris 4.0
DolphinScheduler社区4 天前
DolphinScheduler 3.3.2 如何调用 DataX 3.0 + SeaTunnel 2.3.12?附 Demo演示!
java·spark·apache·海豚调度·大数据工作流调度
YaBingSec4 天前
玄机网络安全靶场:Apache HTTPD 解析漏洞(CVE-2017-15715)WP
java·笔记·安全·web安全·php·apache
SuperherRo5 天前
服务攻防-中间件安全&Apache&Tomcat&Jetty&Weblogic&AJP协议&反序列化&CVE漏洞
中间件·tomcat·apache·jetty·weblogic
回忆2012初秋5 天前
时序库.net平台下的推荐 SonnetDB,一文分析清除他与Apache IoTDB的区同
apache·iotdb
家有娇妻张兔兔6 天前
Apache POI 导出 Word 踩坑实录:Word 分栏为什么做不好左右平铺
c#·word·apache·poi·分栏
HashData酷克数据6 天前
官宣:Apache Cloudberry (Incubating) 2.1.0 正式发布!
apache
weixin_394758036 天前
直播间小程序码生成问题修复代码清单
android·小程序·apache
YaBingSec7 天前
玄机靶场—Apache-druid(CVE-2021-25646) WP
java·开发语言·笔记·安全·php·apache