3

我想在 OSGi 中使用 Apache POI 来编写带有流式 OOXML API (SXSSF) 的 Excel 工作簿。从 POI 3.9 开始提供流 API。

由于最新的 Apache POI 3.11 jar 不是捆绑包:让 POI 在 OSGi 中工作的最佳方式是什么?

我尝试了两种方法:

  1. 将罐子直接嵌入到将使用它们的唯一包中
  2. 使用预先包装为捆绑包的 POI jar

我对将所有依赖项放在一起感到绝望。

首先关于在我的包中嵌入 POI jar:我的 bndtools 文件包含

-buildpath:  \
...
libs/dom4j-1.6.1.jar;version=file,\
libs/poi-3.11.jar;version=file,\
libs/poi-ooxml-3.11.jar;version=file,\
libs/poi-ooxml-schemas-3.11.jar;version=file

Private-Package:  \
...
org.openxmlformats.schemas.*,\
org.apache.poi.*,\
org.dom4j.*,\
com.microsoft.schemas.office.x2006.*,\
schemaorg_apache_xmlbeans.*,\
schemasMicrosoftComOfficeExcel.*,\
schemasMicrosoftComOfficeOffice.*,\
schemasMicrosoftComVml.*

这会导致一个包导入很多很多东西,例如org.bouncycastle.asn1.x509org.junit. 我不打算在我的应用程序中加密或测试 - 所以这两个可能在某种程度上是“可选的”。我该如何指定?有没有收集所有这些依赖项的好方法?

注意:至少org.apache.commons.codeccom.sun.msv.datatype.xsd.lib是额外需要的,但它们已经是捆绑包。


使用预包装的罐子,我尝试使用org.apache.servicemix.bundles.poi3.9_2。这也需要dom4j,所以我使用了预包装org.apache.servicemix.bundles.dom4j但至少需要 1.0 版本javax.xml.stream,我的 JVM/Felix OSGi 将其宣传为“唯一”版本0.0.0.1_007_JavaSE。我手动修复了这个(丑陋),但后来又陷入了另一个依赖。

有什么好办法?

4

2 回答 2

3

我们使用 Gradle 和bnd-platform为我们的应用程序基于 Maven 依赖项构建 OSGi 包。不确定这是否是“好方法”,但这是我们为基于 OSGi 的应用程序构建目标平台的方式,Apache POI 就是其中的一部分。在您必须对包进行调整(例如,使 JUnit 成为可选)或合并 JAR(例如,由于 OSGi 中的类加载问题)以使它们工作的情况下,它特别有用。

我在 GitHub 上使用 Apache POI 包(隐含地,它的 POM 定义的依赖项)建立了一个示例构建。您可以克隆它(sample-poi分支)并尝试运行它./gradlew clean bundles。创建的捆绑包将位于build/plugins.

请注意,默认情况下不会包含任何可选的 Maven 依赖项,如果需要,必须手动将它们添加到构建中(由于Gradle 中的限制)。

于 2015-04-24T08:37:51.700 回答
1

我没有这个工作的工作示例,但这段文档可能对您有所帮助。

POI 可以与 OSGI 一起使用吗?

从 POI 3.16 开始,有一个解决 OSGI 上下文类加载器处理的方法,即它用有限类视图的实现替换线程当前上下文类加载器。这将导致 IllegalStateExceptions,因为 xmlbeans 在此简化视图中找不到 xml 模式定义。解决方法是初始化 POIXMLTypeLoader 的类加载器委托,默认为当前线程上下文类加载器。初始化应该在任何其他 OOXML 相关调用之前进行。示例中的类可以是任何类,它是 poi-ooxml-schema 或 ooxml-schema 的一部分: POIXMLTypeLoader.setClassLoader(CTTable.class.getClassLoader());

于 2018-05-09T17:17:13.240 回答