1

我有以下问题,我在C:\Tomcat85\webapps\MyWebApp\Excel\myExcel.xls.

一旦我的 Java 应用程序完成了文件的写入,它就会执行下载以供用户使用。这会产生令人讨厌的 404 错误。

如果我等待几秒钟并重新加载它下载的页面(或者在 java 中添加五秒钟的睡眠,它的工作原理相同)。

因此,我得出的结论是,Tomcat 需要 5 秒钟来识别这个新的 excel 文件存在,然后才能够为它提供服务。

有没有办法让 Tomcat 更快地执行这个任务?也许在 web.xml 中使用一些配置来区别对待“/Excel/”文件夹。

Windows 10 64 位、Tomcat 8.5、Java 7(可以尝试 java8,但我认为不会有什么不同)。

一些代码:

new ExcelExport(remoteHandle, context).execute( outFileName, outMessage);
// Thread.sleep(5000);
httpContext.wjLoc = formatLink(outFileName);
  • sleep 根据测试被评论或取消评论。没有睡眠,我得到 404,在 5 秒内睡眠它工作正常。
  • httpContet.wjLoc 只是执行下载,作为文件的链接。

写入工作正常,因为我在文件资源管理器中看到它已准备好并且可写,但如果我尝试通过 URL 打开它,我会得到相同的 404。

4

1 回答 1

2

Resources默认缓存。缓存条目重新验证之间的时间间隔(以毫秒为单位)由本文档cacheTtl中引用的参数定义。默认情况下,其值为 5 秒。

如果要禁用缓存,只需将 设置cachingAllowedfalse

于 2017-06-30T18:21:49.633 回答