总结套路:Ajax请求下载文件的问题

这周的开发中在ajax中发现不能下载文件,及时ajax请求到一个controller在跳转到下载的controller上也不能下载,百度了一下总结下原因:发现原来jq的ajax回调已经把response的数据傻瓜式的以字符串的方式解析.而我用SpringMVC 传回的是ResponseEntity<byte[]>数据,所以不行。

解决办法1.ajax返回之后,在回调函数中用window.location.herf='your_downlaod_url'访问下载页面。

2.用Blob处理:

$http({
    url: "http://127.0.0.1:8080/wx-sr-api/xxx/export",
    method: 'GET',
    params: reqData,
    responseType: 'arraybuffer'
}).success(function (data, status, headers) {
    <!--var type = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
    if (!type)
        throw '无效类型';-->

    //对象 URL 也被称为 blob URL,指的是引用保存在 File 或 Blob 中数据的 URL。使用对象 URL 的
    //好处是可以不必把文件内容读取到 JavaScript 中而直接使用文件内容。为此,只要在需要文件内容的地
    //方提供对象 URL 即可。
    var urlCreator = window.URL || window.webkitURL;
    var blob = new Blob([data], { type: type }, decodeURI(headers()["x-filename"]));
    var url = urlCreator.createObjectURL(blob); //这个函数的返回值是一个字符串,指向一块内存的地址。

    //以下代码保存我的excel导出文件
    var link = document.createElement('a'); //创建事件对象
    link.setAttribute('href', url);
    link.setAttribute("download", filename);
    var event = document.createEvent("MouseEvents"); //初始化事件对象
    event.initMouseEvent("click", true, true, document.defaultView, 0, 0, 0, 0, 0, false, false, false, false, 0, null); //触发事件
    link.dispatchEvent(event);

}).error(function (data, status) {

});



//以下代码可以在页面中显示一个图像文件:
var filesList = document.getElementById("files-list");
EventUtil.addHandler(filesList, "change", function(event){
    var info = "",
    output = document.getElementById("output"),
    progress = document.getElementById("progress"),
    files = EventUtil.getTarget(event).files,
    reader = new FileReader(),
    url = createObjectURL(files[0]);
    if (url){
        if (/image/.test(files[0].type)){
            output.innerHTML = "<img src=\"" + url + "\">";
        } else {
            output.innerHTML = "Not an image.";
        }
    } else {
    output.innerHTML = "Your browser doesn't support object URLs.";
    }
});
Blob这个插件我也不是很了解。下周了解一下

3.JQuery的ajax函数的返回类型只有xml、text、json、html等类型,没有“流”类型,所以我们要实现ajax下载,不能够使用相应的ajax函数进行文件下载。但可以用js生成一个form,用这个form提交参数,并返回“流”类型的数据。在实现过程中,页面也没有进行刷新

var form=$("<form>");//定义一个form表单
form.attr("style","display:none");
form.attr("target","");
form.attr("method","post");
form.attr("action","exportData");
var input1=$("<input>");
input1.attr("type","hidden");
input1.attr("name","exportData");
input1.attr("value",(new Date()).getMilliseconds());
$("body").append(form);//将表单放置在web中
form.append(input1);
form.submit();//表单提交


  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值