您的位置:首页 > 其它

Ajax处理下载文件response没有反应

2016-07-26 21:55 393 查看
要实现下载Excel的功能,思路很简单,后台servlet根据数据库的数据生成Excel保存在指定位置,然后保存到response的输入流中,最后将零时的Excel删除:

....
//省略poi生成Excle的过程
....

response.setHeader("content-type","text/html;charset=UTF-8");
response.addHeader("content-disposition", "attachment;filename=" + URLEncoder.encode(fileName + ".xls", "UTF-8"));

InputStream in = null;
OutputStream out = null;
try {
in = new FileInputStream(filePath + "\\" + fileName + ".xls");
int len = 0;
byte[] buffer = new byte[1024];
out = response.getOutputStream();
while((len = in.read(buffer)) > 0) {
out.write(buffer,0,len);
}
}catch(Exception e) {
System.out.println("网络连接故障!错误信息:"+e.getMessage());
}finally {
if(in != null) {
try {
out.close();
in.close();
response.flushBuffer();
}catch(Exception e) {
throw new RuntimeException(e);
}
}
}

fileExcel.delete();//delete the excel in the end


前台ajax也很简单:

$.ajax({
type: "POST",
async: false,
url: regionURL ,
success:function(data){
//          alert(data);
}
});


想法很好,但是现实很残酷,点了下载按钮,一点反应都没!

最后网上查了下,发现问题是ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的。文件的下载是以二进制形式进行的,虽然可以读取到返回的response,但只是读取而已,是无法执行的。

解决方案,不用ajax:

window.location.href=regionURL;


参考
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: