我想在 OSGi 中使用 Apache POI 来编写带有流式 OOXML API (SXSSF) 的 Excel 工作簿。从 POI 3.9 开始提供流 API。
由于最新的 Apache POI 3.11 jar 不是捆绑包:让 POI 在 OSGi 中工作的最佳方式是什么?
我尝试了两种方法:
- 将罐子直接嵌入到将使用它们的唯一包中
- 使用预先包装为捆绑包的 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.x509
和org.junit
. 我不打算在我的应用程序中加密或测试 - 所以这两个可能在某种程度上是“可选的”。我该如何指定?有没有收集所有这些依赖项的好方法?
注意:至少org.apache.commons.codec
和com.sun.msv.datatype.xsd.lib
是额外需要的,但它们已经是捆绑包。
使用预包装的罐子,我尝试使用org.apache.servicemix.bundles.poi
3.9_2。这也需要dom4j
,所以我使用了预包装org.apache.servicemix.bundles.dom4j
但至少需要 1.0 版本javax.xml.stream
,我的 JVM/Felix OSGi 将其宣传为“唯一”版本0.0.0.1_007_JavaSE
。我手动修复了这个(丑陋),但后来又陷入了另一个依赖。
有什么好办法?