POI导出Excel,浏览器不下载的问题解决

本文详细解析了使用POI导出Excel时出现乱码的原因,并提供了一种有效的解决方案,通过改变请求方式避免Ajax对二进制流的错误处理,确保了Excel文件的正常下载。

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

在做POI导出Excel的时候,遇到了浏览器不弹出下载框的问题


问题发现

debug跟进发现输出流已经成功写入,而且程序没有报错,可就是没有下载提示

在前台控制器的XHR-response中查看返回数据,发现是乱码,经过一番查找发现了问题所在

我是使用Ajax访问的后台方法,但是Ajax的数据传输都是字符串形式,而POI返回的Excel数据是二进制流的形式,所以前台会出现乱码问题,导致浏览器认为无法下载


问题解决

既然无法使用Ajax请求,还有window.location.href,或者form表单提交等方式。

由于window.location.href属于get请求,所以使用了后者,代码如下

//在html页面添加一个form表单 
<form id="export"></form>
//导出Excel工具类
function exportExcelUtils(item, url, data) {
    let htmlStr = "";
    let keys = Object.keys(data);
    $.each(keys, function (idx, key) {
        htmlStr += "<input type='hidden' name='" + key + "' value='" + data[key] + "'>";
    });
    item.html("").append(htmlStr);
    item.attr("method", "post");
    item.attr("action", url);
    item.submit();
}
//调用工具类,导出excel
exportExcelUtils($("#export"), "/exportExcel", {
            level: "1",
            name: "zzz",
            age: "25"
        });

注:

工具类代码完全不需要修改,只需要根据自己的需求改第三段代码中的url和数据即可

原理就是将数据保存到表单的隐藏域,然后模拟表单提交调用后台方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值