浏览器不能下载response输出的excel

本文探讨了使用Ajax导出Excel时遇到的问题,包括数据格式转换导致的乱码现象,以及如何通过正确的参数传递和响应设置来解决这些问题。文章提供了具体的代码示例,帮助开发者理解并实现正确的导出流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是否使用ajax提交

用ajax提交是不行的,因为ajax基于XMLHttpRequest ,XMLHttpRequest 的定义就是:可以同步或异步返回 Web 服务器的响应,并且能以文本或者一个 DOM 文档形式返回内容。而我们的Excel是二进制流。所以Excel会被强转成文本,就像乱码一样。(效果类同你用记事本打开Excel文件

测试代码是否正确

在浏览器直接访问下载的URL,如果能自动下载。ok,代码没问题。

常见错误

1.传参问题

如果用浏览器直接访问是get请求,后台不能用@RequestBody

2.响应的设置

首先方法要标记:@ResponseBody
然后response是设置
response.reset();
response.setContentType("application/vnd.ms-excel;charset=utf-8");
response.setHeader("Content-Disposition", "attachment;filename="+ new String(("下载后Excel文件名称" + ".xlsx").getBytes(), "iso-8859-1"));

response写完后
response.flush();response.close();

代码正确,前端请求方式

form提交

var form = $("<form>");
form.attr("style","display:none");
form.attr("target","");
form.attr("method","post");
form.attr("action",rootPath + "user/expostUserExcel.do");
var input1 = $("<input>");
input1.attr("type","hidden");
input1.attr("name","strZipPath");
input1.attr("value",strZipPath);
$("body").append(form);
form.append(input1);
form.submit();
form.remove();

window.open/location.href等

a标签

iframe

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值