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

本文标签: 迅雷浏览器文件