后端返回文件流时,前端如何处理并成功下载流文件以及解决下载后打开显示不支持此文件格式

文章讲述了文件和流的概念,文件作为数据存储的基本单位,流则是抽象的字节序列概念,包括文件流等多种类型。在前端使用Vue处理文件流下载时,需将responseType设为blob,并通过创建Blob对象和a标签实现下载。遇到下载后文件格式不受支持的问题,可能是因为axios的响应拦截导致,解决方案是确保使用res.data来创建Blob对象。
摘要由CSDN通过智能技术生成

一、文件和流的关系

文件(File)和流(Stream)是既有区别又有联系的两个概念。

文件 是计算机管理数据的基本单位,同时也是应用程序保存和读取数据的一个重要场所。
      存储介质:文件是指在各种存储介质上(如硬盘、可移动磁盘、CD等)永久存储的数据        的有序集合,它是进行数据读写操作的基本对象。
     特性:每个文件都有文件名、文件所在路径、创建时间及访问仅限等属性。

流 是字节序列的抽象概念,例如文件、输入/输出设备、内部进程通信管道等。流提供一种         向后备存储器写入字节和从后备存储器读取字节的方式。
    存储介质:除了和磁盘文件直接相关的文件流以外,流还有多种类型。流可以分布在网络      中、内存中或者是磁带中。

 上图类似于乱码,就是文件流在浏览器中的表现形式。

二、前端处理文件流并下载(Vue)

await this.$http
        .request({
          url: `/minioDownload?htitle=${title}`, //这里是你的请求url
          responseType: 'blob', //这里最重要,不要去掉
          method: 'get', //请求方式,看后台的需求,可能是get,post等方式
        })
        .then((res) => {
          console.log(res);
          var elink = document.createElement('a');
          elink.download = name;
          elink.style.display = 'none';
          var blob = new Blob([res], { type: 'application/x-msdownload' });
          elink.href = URL.createObjectURL(blob);
          document.body.appendChild(elink);
          elink.click();
          document.body.removeChild(elink);
          this.$message.success(`文件下载成功!`)
        }).catch(err => {
            console.log(err);
        });

设置Content-Type 的值为:application/x-msdownload。Web 服务器需要告诉浏览器其所输出的内容的类型不是普通的文本文件或 HTML 文件,而是一个要保存到本地的下载文件

三、解决下载后打开显示不支持此文件格式

这个问题我也遇到了,在网上也搜了好多资料,才得到答案。

比如:

是因为在 axios 中对后端的响应做了拦截,所以new Blob([res])中拿到的res实际上是后端接口的  res.data,只不过这一层操作在全局被封装了。

而如果直接使用的$http.get().then(),并未在全局对请求进行封装拦截。所以在这里需要取得的是   res.data    于是,我把new Blob([res])改成new Blob([res.data])后,问题就解决了。

后端返回文件后,前端可以通过以下几种方式实现文件下载导出: 1. 使用`<a>`标签的`download`属性:可以在前端创建一个`<a>`标签,将后端返回文件作为链接的`href`属性值,并设置`download`属性为文件名,这样点击该链接时,浏览器会自动下载文件。 ```html <a href="后端返回文件URL" download="文件名">点击下载</a> ``` 2. 使用`window.open()`方法:可以使用JavaScript的`window.open()`方法打开一个新的窗口,并将后端返回文件URL作为参数传递给该方法,浏览器会自动下载文件。 ```javascript window.open("后端返回文件URL"); ``` 3. 使用`XMLHttpRequest`对象:可以使用JavaScript的`XMLHttpRequest`对象发送GET请求,将后端返回文件作为响应内容,然后通过创建`Blob`对象和`URL.createObjectURL()`方法将文件转换为可下载的URL,最后使用`<a>`标签的`download`属性进行下载。 ```javascript var xhr = new XMLHttpRequest(); xhr.open("GET", "后端返回文件URL", true); xhr.responseType = "blob"; xhr.onload = function() { if (xhr.status === 200) { var blob = xhr.response; var url = URL.createObjectURL(blob); var a = document.createElement("a"); a.href = url; a.download = "文件名"; a.click(); } }; xhr.send();``` 请注意,以上方法中的"后端返回文件URL"需要替换为实际的后端返回文件的URL,"文件名"需要替换为实际的文件名。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值