前端处理文件下载(带请求头)

文件下载,token校验

文件下载通常使用a标签进行处理,本次介绍的是通过blob来实现流文件下载,原因是后台网关校验通过请求头拿token,原来的操作无法实现。在度娘搜索了半个小时候找到了靠谱方案,现在来摘抄一下;原文地址https://blog.csdn.net/elie_yang/article/details/79580533

            function createObjectURL(object) { return (window.URL) ? window.URL.createObjectURL(object) : window.webkitURL.createObjectURL(object); }
            var xhr = new XMLHttpRequest();
            var formData = new FormData();
            xhr.open('get','url');  //url填写后台的接口地址,如果是post,在formData append参数(参考原文地址)
            xhr.setRequestHeader("access-token", sessionStorage.getItem('access-token'));
            xhr.responseType = 'blob';
            xhr.onload = function (e) {
                if (this.status == 200) {
                    var blob = this.response;
                    var filename = "设备导出.xls";
                    console.log(this.response)
                     if (window.navigator.msSaveOrOpenBlob) {
                        navigator.msSaveBlob(blob, filename);
                    } else {
                      var a = document.createElement('a');
                     var url = createObjectURL(blob);
                     a.href = url;
                     a.download = filename;
                     document.body.appendChild(a);
                     a.click();
                     window.URL.revokeObjectURL(url);
                    }
                    
                }
            };
            xhr.send(formData);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容