4

背景

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 使用。

有哪些有用的信息?

从 4.5 到 5 的更新不应该有这个结果。我们需要这个库,否则我们必须回到旧版本,我们的客户不同意。我真的认为最后一个链接中有解决方案,但处理信息非常困难。

4

1 回答 1

4

使用 Lucee 5,您有三个选择:

1) 如果库是 OSGi 包,只需将其放入{lucee-server}/bundles

2) 如果库不是 OSGi 包,就像 Docx4j 的情况一样,将 jar(及其依赖项,如果需要)放入 servlet 容器的类路径中,例如 Tomcat 或 Jetty(或任何您使用的)。

“最简单”的事情是将 jar 放在与 Lucee jar 相同的目录中。

另一种选择是更新容器的类路径,例如在 Tomcat 的情况下将其添加到common.loader其中{catalina-base}/conf/catalina.properties

3) 为你的 jars 指定一个自定义路径,作为参数createObject(java...),或者Application.cfc通过this.javaSettings

至于缺少的依赖项,请务必使用包含所有依赖项的 jar,docx4j-community-3.3.1.zip而不是docx4j-3.3.1.jarhttp://www.docx4java.org/downloads.html下载

于 2016-10-14T16:39:16.503 回答