背景
Docx4j 是一个 Java 库,可用于将 Microsoft Word 文档作为 Java 中的 XML 处理。我们用 Coldfusion 编写的旧应用程序已经正确使用了这个库。然后我们转向更新的软件 Lucee。这已经给实现 Docx4j 库带来了问题。它最终通过将包含所有依赖项的 Docx4j jar 放入文件夹“wwwroot/WEB-INF/lucee/lib”中来工作。重新启动 Lucee 服务后,它正确加载了 jar。还有一些其他问题,但重要的部分是jar被加载到环境中。
那么现在有什么问题呢?
现在我们有一个新项目安装在新的 Lucee 5.0 上。一切正常,只有 docx4j 出现问题。在代码中使用 docx4j 时,它会给出一个错误,指出 Docx4j loggerfactory 未加载。这是 Docx4j 使用的依赖项。我发现一些信息表明 Lucee 5.0 与外部 jar 库的工作方式不同,并且它需要是一个 OSGi 框架包。但是,这再次变得很难理解 Lucee 需要什么才能使其正常工作
我想实现什么
每次与 Coldfusion/Lucee 一起工作的是 jar 文件 Docx4j 以及所有依赖项 jar 文件。所以我把所有这些 jar 文件放在 Coldfusion 读取的文件夹中,然后它就可以工作了。所以我想说的是没有设置文件或类似的东西(可能在 jar 文件本身中?)
我尝试了什么?
所以当然我尝试了几件事:
首先,我尝试将它放在“inetpub/wwwroot/WEB-INF/lucee/lib”中。第一次在前端加载函数时,它指出无法加载 loggerfactory。在此之后调用该函数后,它表示它根本无法加载 docx4j。仍然在管理员中它写道 Docx4j 仍然处于活动状态。
尝试通过 Lucee admin 将其作为 zip 文件上传,它表示上传太大
试着把它放在“lucee/tomcat/lucee-server/context/lib”中。与第 1 点完全相同的问题。我还可以在服务仍在运行时重命名 Docx4j jar。这是不可能的工作示例。在第二次错误发生变化之后,这也很奇怪。这可能是 Lucee 对 jar 文件做了一些事情。
我认为可能的解决方案是什么?
我发现一些信息表明 Lucee 5.0 对 jar 库做了一些不同的事情。现在它期望成为一个 OSGi 包。您可以通过提供使 jar 文件成为捆绑包的 manifest.xml 文件来制作捆绑包。但我不知道我应该怎么做。而且因为它总是与以前的版本一起工作,我认为解决方案可能非常简单。即添加一条说明依赖关系的行。所以也许是一个 cfadmin 标记,它加载这些依赖项以供 Docx4j 使用。
有哪些有用的信息?
- 我从错误/jar 文件中截取的一些屏幕截图:https ://postimg.org/gallery/39zbmifbi/
- 这是有同样问题的人:https ://groups.google.com/forum/#!topic/lucee/LKRS7otUYjc
从 4.5 到 5 的更新不应该有这个结果。我们需要这个库,否则我们必须回到旧版本,我们的客户不同意。我真的认为最后一个链接中有解决方案,但处理信息非常困难。