首页 >后端开发 >php教程 >下载请求不能放在ajax里发送的原因

下载请求不能放在ajax里发送的原因

零到壹度
零到壹度原创
2018-04-10 09:44:181620浏览

本篇文章给大家分享的内容是下载请求不能放在ajax里发送的原因 ,有着一定的参考价值,有需要的朋友可以参考一下

最近在做文件下载,后台写了个控制层,直接走进去应该就可以下载文件,各种文件图片,excel等

但是起初老是下载失败,并且弹出下面的乱码:

前台请求代码:

$('#fileexcel').unbind('click').bind('click',function(){
                    alert("我要下载了");
                    $.ajax({
                        type:'post',
                        url:'media',
                        data:null,
                        async:true,
                        success : function(msg){
                            alert(msg);
                        }
                    })
                })

看起来貌似没有任何问题,但就不能下载。

本来认为是后台代码有问题,但是将网上的各种demo放进去还是有问题。

在坑了一天后,终于发现问题所在了。

那就是请求方式有问题,文件下载的请求是不能写在ajax里面的!

写成下面这样的就可以了:

<a href="/media">点击下载Excel</a>
或者
location.href = &#39;/media&#39;;

这次点击下载就出现如下理想效果。


然后总结一下为什么下载请求不能放在ajax里发送:

原因:因为response原因,一般请求浏览器是会处理服务器输出的response,例如生成png、文件下载等,然而ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的。文件的下载是以二进制形式进行的,虽然可以读取到返回的response,但只是读取而已,是无法执行的,说白点就是js无法调用到浏览器的下载处理机制和程序。

相关推荐:

不能用ajax请求下载文件

Ajax请求无法下载文件的原因

文件下载不能使用ajax的替代解决方案

以上是下载请求不能放在ajax里发送的原因的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn