js下载文件,判断文件是否返回

摘要:下载之前用的window.location.href下载的,但是这个判别不了文件是否返回,小文件倒还好,大的文件长时间没有下载也没有加载条什么的,用户有时会点击下载好几下,大的数据很容易将服务拖垮

下载之前用的window.location.href下载的,但是这个判别不了文件是否返回,小文件倒还好,大的文件长时间没有下载也没有加载条什么的,用户有时会点击下载好几下,大的数据很容易将服务拖垮,所以决定改良下,参考网上大神的,大概思路是:用ifram标签下载,追加到文档,下载完成移除,前端带一个时间戳的cookie,后台接收,下载完成之后返回,前端一个定时循环的函数去验证是不是返回了时间戳,如果是确认下载成功


前端代码:

$("#mylink").click(function () {
	var iframe=document.createElement("iframe");
	//指定iframe的路径
	iframe.src= dss.rootPath + "plugin/sjwfx/NineAddressNoLeisUreExport";
	$(iframe).css("display","none");
	//开始“数据正在加载”的进度条,提示用户在导出数据
	dss.alert("正在为您导出数据,请稍后片刻");
	dss.load(true);
	//追加元素到文档
	document.body.appendChild(iframe);
	//每隔一秒循环下里面代码,如果是我返回的值,关闭加载
	var interval = setInterval(function(){
    //获取返回的cookie
    var down = dss.cookie.get("resultId");
    if(down=="75941785"){
	    //隐藏“数据正在加载”的进度条
	    dss.load(false);
	    $(iframe).remove();
	    //关闭循环的时间函数
	    clearInterval(interval);
    }
	},1000);
});

后台添加这么几行代码:

Cookie cookie=new Cookie("resultId","75941785");//将时间戳设置到cookie中
 cookie.setPath("/");//可能会出现前端js读取不到,所以设置下
cookie.setMaxAge(10);//设置cookie生存时间,可调小一点
response.addCookie(cookie);//添加cookie


我前端没有带上时间戳,因为iframe的关系,我这是iframe嵌在iframe里面的,后台一直读取不到我带的cookie,百度了很多没有很好的解决办法,所以我是直接在后台带上值,前端识别,我是设置了cookie时间为十秒就失效,注意:后台如果配置文件配置了http-only,前端js是不能读取操作的,还有就是setPath不是必须带的,如果前端读取不到,试着带下,或者指定你的项目名。


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_3479