复杂 Web 应用程序上的 ConversionInputException



当我在特定转换器上同时调用execute()schedule()方法时,我得到了这个ConversionInputException

我认为代码是正确的,因为如果我将代码作为简单的 java 应用程序执行,它可以与输入相同的文件完美运行。

当我将代码部署为 jar 并从复杂的 Web 应用程序调用代码时,我总是有这个ConversionInputException.

我也尝试使用 InputStream 而不是 File 对象,但我有同样的例外。

我能够毫无问题地使用 MS-Word 打开文件,并且我还能够在运行相同代码的独立 java 应用程序中转换它。

这是我使用的代码

private void convert(File inputFile, File outputFile) {
     boolean conversion=false;
     IConverter converter=com.b80.common.d2.wf.utility.CustomConverter.getInstance().getConverter();
     conversion = converter.convert(inputFile).as(DocumentType.MS_WORD)
                          .to(outputFile).as(DocumentType.PDF)
                          .prioritizeWith(1000).execute();
}

它开发的转换器类如下 - 我必须使用同步方法,因为转换器的实例可以通过服务器上的多个线程访问:

import java.io.File;
import java.util.concurrent.TimeUnit;
import com.documents4j.api.IConverter;
import com.documents4j.job.LocalConverter;
public class CustomConverter {
    private static IConverter converter=null;
    private static final String CONVERSION_FOLDER="E:\temp\document4j";
    private static CustomConverter instance = null;
    private CustomConverter() {
      // Exists only to defeat instantiation.
    }
    public static synchronized CustomConverter getInstance() {
      if(instance == null) {
         instance = new CustomConverter();
      } 
      return instance;
   }
    public synchronized IConverter getConverter() {
    if(converter==null || !converter.isOperational()) {
        converter=LocalConverter.builder().baseFolder(new File(CONVERSION_FOLDER)).workerPool(20, 25, 5, TimeUnit.MINUTES)
                .processTimeout(10, TimeUnit.MINUTES)
                .build(); 
    }       
    return converter;
  }
}

这是 StackTrace,显然例外在 convert() 函数上。

2016-04-28 16:52:21,483 ERROR [STDERR] (http-0.0.0.0-9080-1) com.documents4j.throwables.ConversionInputException: The input file seems to be corrupt
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.util.Reaction$ConversionInputExceptionBuilder.make(Reaction.java:159)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.util.Reaction$ExceptionalReaction.apply(Reaction.java:75)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.conversion.ExternalConverterScriptResult.resolve(ExternalConverterScriptResult.java:70)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.conversion.ProcessFutureWrapper.evaluateExitValue(ProcessFutureWrapper.java:48)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.conversion.ProcessFutureWrapper.get(ProcessFutureWrapper.java:36)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.conversion.ProcessFutureWrapper.get(ProcessFutureWrapper.java:11)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at com.documents4j.job.AbstractFutureWrappingPriorityFuture.run(AbstractFutureWrappingPriorityFuture.java:78)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
2016-04-28 16:52:21,484 ERROR [STDERR] (http-0.0.0.0-9080-1)    at java.lang.Thread.run(Thread.java:662)

我更深入地分析了代码并将一些日志添加到 word_convert.vbs 中,我得到了如下错误消息:

Error # 424 Object required

我知道这是一个有点笼统的信息,但我希望它可以提供更多帮助。

我是 documents4j 的作者,一般来说,我认为这是一个用户问题,因为我在许多环境中成功运行了 documents4j,但从未遇到过这样的问题。

很难说问题是什么,因为我不知道究竟是什么使您的Web应用程序变得复杂。由于响应表明您的文件已损坏,并且由于转换器确实可以在没有应用程序复杂部分的情况下工作,因此我假设您在某个时候确实损坏了文件。

我可以建议您尝试调试:

  1. 实现一个伪转换器,该转换器仅接收字节数组并发回虚拟文件。检查收到的字节是否等于原始文件的字节数。也许你正在切断一些价值观?
  2. 逐步将您的应用程序简化为有效的简单应用程序,并查看流程中的哪个步骤破坏了您的前提。

相关内容

  • 没有找到相关文章

最新更新