大家好,我遇到了一个问题。更新下:其实outputstream.write就是附加操作,而不是重写。举例来说,第一次write并且flush以后,后面再flush也能推送到客户端,而且是追加。我的问题是,后面追加的操作没能写入到第一次生成的excel中。在资源管理器中看文件大小是28kb,打开后再关闭就变成了8kb。原问题:客户端想要下载excel文件,我从数据库里找到,然后用apachepoi生成bytearray,设置好响应头,再传回客户端,客户端就可以下载。问题就是,有时候生成这个excel的耗时比较长,浏览器没收到响应,就504超时了。我想着能不能生成一部分,发送一部分,这样连接就建立起来了。一直到所有的内容都生成了,再关闭连接。我用的是servlet.getOutputStream(),没找到类似append的方法,PrinterWriter类有类似的方法,但是我试了一下,这样传回客户端的没法打开,应该是只能传二进制回去吧?我还试了一下socket,但是也需要用socket.getOutputStream();的方法获取输出流,这样又绕回来了。所以来这里请教下各位,有没有其它方式能实现我这需求,还是这个需求就是不可实现的?如果有更好的方法,还请赐教。谢谢!
2 回答
慕森卡
TA贡献1806条经验 获得超8个赞
可以实现的,但是比较麻烦,因为你用poi只能得到一个outputstream,而如果想用流方式提供给客户端下载,需要有一个inputstream,所以你需要一个PipedInputStream,然后把outputstream转换为一个inputstream,然后你还需要准备一个单独的线程去实现poi的操作,否则在同一个线程里,你没办法同时对outputstream和inputstream进行操作,所以还是比较麻烦,但可以做到。代码的例子没有找到合适的,你可以看看PipedInputStream/PipedOutputStream的相关文档。
ibeautiful
TA贡献1993条经验 获得超5个赞
你可以先返回一个页面就像平时下载文件的数据处理中下载将在一分钟后开始....之类的把处理完的文件保存起来,时间到把链接显示出来,或者自动请求,然后请求来的时候把文件发过去处理时间不长的话,也可以试着把超时时间设长一点
添加回答
举报
0/150
提交
取消