admin管理员组文章数量:1663949
2019独角兽企业重金招聘Python工程师标准>>>
以前并没有特别注意过,文件下载都是输出一个流文件,放在response中返还给浏览器就可以下载文件了。上次突然发现迅雷不能下载这样的文件(虽然现在迅雷用的比较少了)。
上网查了一部分资料,整理常见的一些说法如下(因为资料来源比较琐碎,就不特别记载了,事实上我没有看到特别完整的解决方案和原因分析):
1. response返回流文件时使用了session,迅雷会两次请求servlet导致session丢失(也就是说迅雷真正下载的地址是下不到数据的)。
2. response没有返回文件信息或者设置正确的文件长度,常见设置是:
response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes()));
response.addHeader("Content-Length", "" + file.length());
response.setContentType("application/octet-stream");
3. 有一种解决方案是在服务器生成一个文件让迅雷下载(返回指定地址给迅雷,注意要是有效地址,即任意访问都能下载的地址)
总结:
1. Java下载文件离不开response,不能下载往往是一些其他因素引起的。
2. 看来有时间要试着写一个Demo玩一下各种上传下载(包括2GB以上大文件、断点续传等),也可以观摩一下开源的文件处理程序,比如百度的WebUploader
转载于:https://my.oschina/mumureb510/blog/1613735
版权声明:本文标题:文件下载(浏览器下载与迅雷下载) 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1730014216a1219156.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论