发布在服务器上部署时导出到PPTX的下载报告

Jac*_*oen 7 java powerpoint jasper-reports

我们使用JasperReports 5.6.1生成报告,并允许将相同的模板导出为PDF或Powerpoint.在本地运行时,下载的PDF和PPTX文件完美运行.当我们部署到我们的服务器时,PDF工作正常,但无法打开PPTX文件.当我们在本地运行时,它被部署到tomcat,但是当部署到服务器时,它在Websphere上运行.

我试过并注意到的事情:

  • 我检查了日志,没有任何例外或任何东西可以引起任何关注.
  • 下载的文件通常比我们在本地运行时获得的文件略大.
  • 如果我将文件的扩展名更改为zip,并将其取消归档.文件结构和文件名是相同的,文件实际上是相同的文件大小.内容似乎只在每张幻灯片中找到的对象的名称中有所不同.
  • 认为这可能是x我尝试导出到xlsx 的类型文件的问题,只是为了看看会发生什么,并且它可以使用相同的模板工作正常.
  • 我添加了一个已知良好的静态pptx文件,可以从服务器上下载它而不会出现问题.我这样做是为了尝试从问题中消除服务器配置,并感觉它有效,我假设它是我的代码,只是不确定是什么.

以下是我们编写响应的代码:

if ("xlsx".equals(type)) {
    response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
    response.setHeader("Content-Disposition", "attachment; filename=" + filename + ".xlsx");
} else if ("pptx".equals(type)) {
    response.setContentType("application/vnd.openxmlformats-officedocument.presentationml.presentation");
    response.setHeader("Content-Disposition", "attachment; filename=" + filename + ".pptx");
    response.setCharacterEncoding("UTF-8");
} else {
    response.setContentType("application/pdf");
    response.setHeader("Content-Disposition", "attachment; filename=" + filename + ".pdf");
}
try (final ByteArrayOutputStream reportResult = reportsService.generateReport(
        getDeal(userId, dealId, sessionStore),
        getScenarioModel(userId, dealId, scenarioId, sessionStore), reportId, type)) {
    configureResponse(response, type, reportResult, dealId + "-" + scenarioId);
    // Write to http response
    reportResult.writeTo(response.getOutputStream());
}

response.flushBuffer();
Run Code Online (Sandbox Code Playgroud)

我已经没有关于故障排除步骤的想法,并且无法在本地重现它,我发现很难诊断.

Goj*_*tah 4

这有点盲目,但您确定您的 WebSphere 实例中的 MIME 类型配置正确吗?(我意识到在响应中设置内容类型应该可以避免为该 MIME 类型配置 Web 服务器的要求,但它毕竟是 WebSphere ;-))

我敢打赌 PDF 是配置的 MIME 类型,但 PPTX 不是。你可以检查一下吗?

  1. 登录 WAS 管理控制台
  2. 前往虚拟主机
  3. 单击名为 MIME 类型的链接

这是更详细的技术说明

IIRC 与 Tomcat 不同,Tomcat 是一种“捆绑”的一体式 http 堆栈和 servlet 容器,WebSphere 具有单独的 http 堆栈(以及每个应用程序的单独 JVM),因此它是毫不奇怪,那里可能需要一些简单容器不需要的配置。