Vue接收后端传过来excel表格的文件流并下载
题外话:当接收文件流时要确定文件流的类型,但也有例外就是application/octet-stream类型,主要是只用来下载的类型,这个类型简单理解意思就是通用类型类似 var 、object、array 这样什么都可以存的类型,传到前端就是一堆文字没有类型需要指定(后面说)
需要asp.net core后端代码的可以访问https://www.cnblogs.com/liaote/p/15411667.html
首先要先看看后端传过来的是一些什么东西,要是传过来就不对那不是花冤枉功夫改
这是传过来正确格式也就是可以接收的格式(blob类型)

下面这种时错误的格式,但不是数据出错,是类型。上面说了这是一个通用类型,所以必须指定类型才能正确显示

vue接收asp.core传过来的文件流,跟asp.net视图用a标签点击下载类似但不同
当然如果不考虑安全性并不需要token验证等可以直接下载
this.axios.get("api/xxx/xxxx",this.xxx)
.then((res)=>{
if(typeof res.data.downloadId=='undefined')this.$message.error(res.data.msg);
else{
const elink=document.createElement('a');
elink.style.display='none';
elink.href='/api/地址/xxxid='+res.data.downloadId;
elink.target='_blank';
elink.click();
}
});
下面这是我们接收的时候一般是这样通过接口让后端传值过来 ,但是这种访问后端接口返回回来的是错误的格式,正确的是需要传递一个blob类型到后端确定类
var filename='下载.xlsx';
this.axios.get("api/xxx/xxxx",this.filter)
.then((res)=>{
let blob=new Blob([res.data],{type:res.data.type})
//兼容ie
if(window.navigator && window.navigator.msSaveBlob){
window.navigator.msSaveBlob(blob,filename);
}else{
var downloadElement=document.createElement('a');
var href=window.URL.createObjectURL(blob);
downloadElement.href=href;
downloadElement.download=filename;
document.body.appendChild(downloadElement);
downloadElement.click();
window.URL.revokeObjectURL(href);
}
});
正确为下面代码 前端需要传递一个 responseType:'blob' 指定类型到后端处理确定类型 后端也要加一个[FromQuery]属性,这样前端来确定类型和后端就区分开了,后端只需要传通用类型就可以了 **注意要使用get请求,后端需要加一个字段,post请求传递这个类型无用
var filename='下载.xlsx';
this.axios.get("api/xxx/xxx",{params:this.filter,responseType:'blob'})//这里的传递要加responseType:'blob'指定类型,后端不需要处理这个类型,只需要传过去就行
.then((res)=>{
let blob=new Blob([res.data],{type:res.data.type})//就是这里一点差距
//兼容ie
if(window.navigator && window.navigator.msSaveBlob){
window.navigator.msSaveBlob(blob,filename);
}else{
var downloadElement=document.createElement('a');//模拟一个a标签与asp.net试图操作类似
var href=window.URL.createObjectURL(blob);//转成链接让其能供人下载
downloadElement.href=href;//a标签的href
downloadElement.download=filename;//a标签的下载名字
document.body.appendChild(downloadElement);//注册这个控件将这个组件加到body尾部
downloadElement.click();//注销掉
window.URL.revokeObjectURL(href);//清除生成的链接,会占用一些东西,不知道啥,反正运行慢点
}
});
后端也需要处理一下让前端能自己确定类型 加一个[FromQuery]来接收 ,不加的话get后端不接收前端请求,post又收不到类型
public async Task<IActionResult> xxx([FromQuery]Model model)//需要加一个[FromQuery]
// [FromHeader] 请求标头
// [FromQuery] 请求查询字符串参数
// [FromForm] 请求正文中的表单数据
// [FromBody] 请求正文
// [FromRoute] 当前请求中的路由
// [FromServices] 作为操作参数插入的请求服务
这样前端就能接收到正确的格式的文件流,以下就可以看到有文件流类型并能看到格式化了不是乱糟糟一团

需要asp.net core后端代码的可以访问https://www.cnblogs.com/liaote/p/15411667.html
希望上述内容能帮助到你
Vue接收后端传过来excel表格的文件流并下载的更多相关文章
- js要怎么接收后端传的excel文件流?
方法1: 无需js,直接用a标签去接你的输出流 <a href="<你的返回流的Action路径>" >下载</a> 方法2:使用js,前提是你 ...
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- js接收文件流并下载
js接收文件流并下载 标签(空格分隔): js 在此输入正文 <script type="text/javascript"> function download(fil ...
- vue项目使用js-xlsx进行excel表格的导入和导出方法的简单原型封装
前提:已经安装好 file-saver xlsx和 script-loader,如未安装,请查看 https://www.cnblogs.com/luyuefeng/p/8031597.html 新建 ...
- 图片上传利用request.getInputStream()获取文件流时遇到的问题
图片上传功能是我们web里面经常用到的,获得的方式也有很多种,这里我用的是request.getInputStream()获取文件流的方式.想要获取文件流有两种方式,附上代码 int length = ...
- Vue导出json数据到Excel表格
一.安装依赖 npm install file-saver --save npm install xlsx --save npm install script-loader --save-dev 二. ...
- 从数据库的表导出到Excel表格中【让客户端下载的Excel】
原文发布时间为:2008-10-11 -- 来源于本人的百度文章 [由搬家工具导入] 这个例子是从gridview中导出到Excel,可以举一反三,可以直接从数据库中取值放在DataSet中,然后再从 ...
- 精讲RestTemplate第6篇-文件上传下载与大文件流式下载
本文是精讲RestTemplate第6篇,前篇的blog访问地址如下: 精讲RestTemplate第1篇-在Spring或非Spring环境下如何使用 精讲RestTemplate第2篇-多种底层H ...
- 如何在SimpleNVR用Excel表格将通道配置简单化
进入本世纪的第三个十年,流媒体们"绞尽脑汁",依靠技术不断提升用户的体验感.熟悉SimpleNVR的用户都知道,目前SimpleNVR已实现对接自有流媒体服务器平台,不限制观看人数 ...
随机推荐
- MapReduce 示例:减少 Hadoop MapReduce 中的侧连接
摘要:在排序和reducer 阶段,reduce 侧连接过程会产生巨大的网络I/O 流量,在这个阶段,相同键的值被聚集在一起. 本文分享自华为云社区<MapReduce 示例:减少 Hadoop ...
- 3.17学习总结.listview用法总结
今天复习了listview控件的用法. 1.activity_main.xml 中的代码,如下: <?xml version="1.0" encoding="utf ...
- git合并内容的1个方式
诉求 把自己的改动的文件合并到目标分支: 不想改那些不属于自己开发时出现的冲突: 操作 开发分支dev,要合并至master分支 1 所有改动都已提交,保持分支的干净状态(working tree c ...
- pycharm 操作excel
一.安装openpyxl Python中,往excel写入数据通常使用openpyxl库.也可以使用pandas库.这里讲解如何通过openpyxl库操作excel.pip install openp ...
- 如何解决SVN Upgrade working copy问题
电脑还原系统后,安装了最新版本的SVN,发现原来在svn检出的文件夹出现了SVN Upgrade working copy,没有commit ,没有update. 在网上查询到:出现这个的原因是因为你 ...
- 一文让你彻底理解having和where的区别
having子句与where都是设定条件筛选的语句,有相似之处也有区别. having与where的区别: having是在分组后对数据进行过滤 where是在分组前对数据进行过滤 having后面可 ...
- 直接取PHP二维数组里面的值
具体是这样的,如下一个二维数组,是从库中读取出来的. $user = array( 0 => array( 'id' => 1, 'name' => '张三', 'email ...
- robot framework使用SeleniumLibrary打开谷歌浏览器无头模式
注:我百度了一圈并没有发现类似的教程 robot framework的seleniumLibrary一般打开浏览器的方式是用关键字 Open Browser 但是,阅读seleniumLibrary ...
- 踩坑系列《八》解决Win10没有找到Hyper-v的错误
最近要安装docker,所以得开启Hyper属性面板,找了下,发现电脑上没有看到该属性. 在这之前,得先判断,你电脑是不是支持Hyper,打开cmd窗口,输入systeminfo 看看最下面Hyper ...
- xLua自定义加载器
xLua入门基础 环境配置 github下载xLua文件: xLua是腾讯开发,据说比较先进: 下载下来后将Plugins和XLua文件夹考进项目: Plugins多平台权限:XLua和C#交互: t ...