web的response输出给浏览器下载过程观测
来源:互联网 发布:天香捏脸数据 编辑:程序博客网 时间:2024/05/16 15:19
用户想要打包后台的几个excel文件为zip包后下载,
我想,可以直接打包成zip文件在本地,然后再把这个文件输出给用户。
还有一种是打包成一个缓存的二进制zip包,然后用outputstream直接write给用户。这种情况比较特殊:
过程是读一个excel,压缩成zip文件的一部分后写到outputstream.write中,问题来了,如果有4个excel,压缩了两个之后报异常终止了,也就是outputstream.write只是write了两个excel的压缩内容,还没有结束,这时候服务器直接停了。
猜测:如果是outputstream.write完成之后用户才开始提示接收文件,也就是说outputstream.write只是把字节流写入到服务器,完成写入后才一起发送到浏览器,这样就可以把部分压缩的内容先发送到response的outputstream。
但是经过观察浏览器的下载行为,只要有outputstream.write(buffer),浏览器已经开始能够选择保存位置了,也就是说servlet的response刚开始输出,浏览器就接收到了,而不是先缓存在outputstream中。
这样就必须先要把压缩文件压缩完毕之后,再通过outputstream输出,不然压缩到一半抛异常,用户接收到的不过是半成品,肯定回投诉的。
另外,浏览器是再outputstream完成后才知道文件大小的,即使这时候还没接收完毕。
如果接收的文件很大,那么outputstream的流虽然close了,但是其数据流只是输出到通向浏览器的那个缓存管道(暂且这么说吧),这时候服务器会完成接下来的传输工作。
以上只是个人猜测,并未看过源码实现,勿误。
- web的response输出给浏览器下载过程观测
- 浏览器不能下载response输出的excel
- python web服务器response()输出的问题
- response输出文件的时候,解决迅雷下载的问题
- C# response输出要下载的文件流到客户端
- web开发过程中,浏览器无法弹出Excel下载的提示
- WEB项目用Response下载
- 部分可观测Markov决策过程的上界近似算法
- 浏览器访问web资源的过程
- 浏览器访问web资源的过程
- 浏览器访问 web服务器 的过程
- 通过response输出流实现下载功能
- response.setContentType防止输出文件被下载
- web浏览器和web服务器的交互过程
- servlet response的输出格式
- response的OutputStream输出数据
- response的write输出问题
- 异常值的观测
- 【动态】万事达卡暗示计划开发区块链结算系统
- Spring Boot+MySql 登录注册
- Java多线程系列--“JUC集合”01之 框架
- 【国际】欧盟预算修正案呼吁进行百万级别区块链投资
- 【动态】以太坊拜占庭硬分叉延后,进行更多测试
- web的response输出给浏览器下载过程观测
- ubuntu里如何激活root账户
- SecureCRT配置屏幕内容输出到log文件
- effective c++读书笔记(二)
- 网络层基础(一)
- 权利是项目经理的一把利剑
- cookie的路径问题
- 如何解决WordPress博客WP_Image_Editor_Imagick漏洞
- sql 排序分页