美文网首页涨知识
前端处理文件下载(带请求头)

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

作者: 秃头大叔 | 来源:发表于2018-06-22 11:00 被阅读0次

文件下载,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);

相关文章

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

    文件下载,token校验 文件下载通常使用a标签进行处理,本次介绍的是通过blob来实现流文件下载,原因是后台网关...

  • 文件上传与下载

    文件上传 前端页面 Action处理类 struts.xml 文件下载 前端页面 处理下载请求的action st...

  • PHP文件系统之文件下载

    文件下载,需要设置http的请求头信息,目的是告诉浏览器,处理这个文件的方式

  • js 文件保存下载

    ajax下载文件下载文件最简单的是用get方法配合前端的a标签,但是如果是post方法或者是请求需要加头信息就需要...

  • 文档下载功能实现

    一、文档下载功能 1.分析 业务处理流程: 判断前端传的文件id是否为空,对应的文件是否存在 请求方法:GET u...

  • JavaScript 接收excel文件流并下载

    条件:后端接口请求返回文件流,前端处理文件流转换成下载地址并下载实现方法有二,一通过Blob对象和createOb...

  • AFN 基本使用

    GET&POST 请求 文件下载 文件上传 序列化处理 监听网络状态 GET 方式发送请求 POST方式发送请求 ...

  • 【关于下载文件】

    一个链接 ,放浏览器中会下载一个文件出来。 处理方式有2类 1 前端处理成文件 2 后端处理成文件 1 前端处理成...

  • AFNetworking下载,设置请求头

    使用AFNetworking下载文件时,为期设置请求头,如下:

  • 填坑:前端导出csv文件

    在前后端分离的情况下,通常前端浏览器提供用户文件下载的功能的实现方式如下: 前端请求后端api 后端根据前端的请求...

网友评论

    本文标题:前端处理文件下载(带请求头)

    本文链接:https://www.haomeiwen.com/subject/qxfkyftx.html