🌟文件和流的关系
文件(File)和流(Stream)是既有区别又有联系的两个概念。
文件
是计算机管理数据的基本单位,同时也是应用程序保存和读取数据的一个重要场所。
存储介质
:文件是指在各种存储介质上(如硬盘、可移动磁盘、CD等)永久存储的数据的有序集合,它是进行数据读写操作的基本对象。特性
:每个文件都有文件名、文件所在路径、创建时间及访问仅限等属性。
流
是字节序列的抽象概念,例如文件、输入/输出设备、内部进程通信管道等。流提供一种向后备存储器写入字节和从后备存储器读取字节的方式。
存储介质
:除了和磁盘文件直接相关的文件流以外,流还有多种类型。流可以分布在网络中、内存中或者是磁带中。
🌟后端返回来的流是什么样子的
这里用一张图片来说明一下
如上图,红色框内,类似于乱码的,就是文件流在浏览器中的表现方式
🌟前端处理文件流并且成功下载
这里以Vue为主实现
在导出接口文件里写入:
import request from '@/utils/request';
// 车辆运行分析导出
export function exportCarRunAnalyse(data) {
return request({
responseType: 'blob', // 重点,responseType设置为 blob
url: '/statistics/exportCarRunAnalyse',
method: 'post',
data
});
}
调取该接口的页面里写入:
// data 为 向后台传递的参数,大家自行定义
exportCarRunAnalyse(data).then(res => {
console.log(res); // 控制台输出:Blob {size: 30208, type: 'application/x-msdownload'}
var debug = res;
if (debug) {
var elink = document.createElement('a');
elink.download = '导出表格.xls';
elink.style.display = 'none';
var blob = new Blob([debug], { type: 'application/x-msdownload' });
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
} else {