Vue接收Asp.Net Core传递的文件并下载,接收application/octet-stream类型文件流并下载

本文主要是介绍Vue接收Asp.Net Core传递的文件并下载,接收application/octet-stream类型文件流并下载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

vue接收后端传过来excel表格的文件流并下载

题外话:当接收文件流时要确定文件流的类型,但也有例外就是application/octet-stream类型,主要是只用来下载的类型,这个类型简单理解意思就是通用类型类似 var 、object、array 这样什么都可以存的类型,传到前端就是一堆文字没有类型需要指定(后面说)

需要asp.net core后端代码的可以访问https://blog.csdn.net/weixin_45973327/article/details/120566699

首先要先看看后端传过来的是一些什么东西,要是传过来就不对那不是花冤枉功夫改

这是传过来正确格式也就是可以接收的格式(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})//兼容ieif(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})//兼容ieif(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标签的hrefdownloadElement.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://blog.csdn.net/weixin_45973327/article/details/120566699

希望上述内容能帮助到你

这篇关于Vue接收Asp.Net Core传递的文件并下载,接收application/octet-stream类型文件流并下载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/723155

相关文章

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

java Stream操作转换方法

《javaStream操作转换方法》文章总结了Java8中流(Stream)API的多种常用方法,包括创建流、过滤、遍历、分组、排序、去重、查找、匹配、转换、归约、打印日志、最大最小值、统计、连接、... 目录流创建1、list 转 map2、filter()过滤3、foreach遍历4、groupingB

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

详解Spring Boot接收参数的19种方式

《详解SpringBoot接收参数的19种方式》SpringBoot提供了多种注解来接收不同类型的参数,本文给大家介绍SpringBoot接收参数的19种方式,感兴趣的朋友跟随小编一起看看吧... 目录SpringBoot接受参数相关@PathVariable注解@RequestHeader注解@Reque

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景