我想在 OSGi 中使用 Apache POI 通过流式 OOXML API (SXSSF) 编写 Excel 工作簿。流媒体 API 自 POI 3.9 起可用。
由于最新的 Apache POI 3.11 jar 不是捆绑包:让 POI 在 OSGi 中工作的最佳方法是什么?
我尝试了两种方法:
- 将 jar 直接嵌入到将使用它们的唯一包中
- 使用预先打包成捆绑包的 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
and org.junit
。我不打算在我的应用程序中加密或测试 - 所以这两个可能在某种程度上是“可选的”。我该如何指定这一点?有没有一种好方法来收集所有这些依赖项?
注:至少org.apache.commons.codec
and 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
。我手动修复了这个问题(丑陋),但随后陷入了另一个依赖项。
有什么好办法呢?