您的位置
主页 > 网站技术 > 语言编程 > » 正文

window.location.href中url中数据量太大时的解决方法

来源: 站长圈 点击:

本文主要为大家介绍下window.location.href中url中数据量太大时的解决方法,需要的朋友可以参考一下,希望对大家有所帮助!

先说一下今天遇到的问题

一个导出excel的处理,在按钮按下后需要传很大一个数据到后台,刚开始的做法如下:

复制代码 代码如下:

var actionUrlSetData = "****Action!exportDatas.action"+ "?now=" + new Date().getTime();

window.location.href= actionUrl + "&" + data;

上面的data就是一个很长的字符串。 

这样在火狐和谷歌浏览器都是没有问题的,但是在ie9(其他ie没试,应该同理)就不能正常导出

导致这个问题的原因是各种浏览器对URL解析的长度限制是不同的,ie就是最小的那个,所以出问题

Microsoft Internet Explorer (Browser)

IE浏览器对URL的最大限制为2083个字符,如果超过这个数字,提交按钮没有任何反应。

Firefox (Browser)

对于Firefox浏览器URL的长度限制为65,536个字符

Safari (Browser) 

URL最大长度限制为 80,000个字符。

Opera (Browser) 

URL最大长度限制为190,000个字符。

Google (chrome) 

url最大长度限制为8182个字符

这里还要注意的是WEB服务器对URL的长度也有限制!!

因此不能用Get方法了,只能想办法用post传值,从而有了下面的方案,不知妥否,还请高手指点,总之功能是可以实现了

思路是用post把那个长长的字符串传到后台,保存到session中,在post的回调方法中再用window.location.href

代码如下:

复制代码 代码如下:

$.post(actionUrlSetData,mapList ,function(){

        var actionUrl = path + "/***action!exportDatas.action"+ "?now=" + new Date().getTime();

        window.location.href= actionUrl + "&" + (data);

    });




首页  - 关于站长圈  - 广告服务  - 联系我们  - 关于站长圈  - 网站地图  - 版权声明