Excel下载workbook都写入到输出流了,浏览器为什么还是没下载文件

debug的时候可以看到后台是走到了return null那一行的,workbook没有问题,out流里也有数据,后台无报错,ajax的回调函数也走进了success里头,但偏偏浏览器就是不给出文件

用浏览器查看该请求的返回发现是一堆乱码,可确定是前端的问题

经人指点说,ajax不能用做文件的导出,因为他无法接受后台文件流,需要用window.open(url);或者window.location.href = "url" 修改了请求方式后成功搞定

 window.open和window.location.href的区别
window.location是window对象的属性,而window.open是window对象的方法

window.location是你对当前浏览器窗口的URL地址对象的参考!   
window.open是用来打开一个新窗口的函数! 

结论:文件导出时不要用ajax发起请求!!!它无法接受后台文件

 

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...