前台Vue使用axios实现文件下载功能,巨坑,一个简单的下载用了一天多才弄出来 我服

本文主要是介绍前台Vue使用axios实现文件下载功能,巨坑,一个简单的下载用了一天多才弄出来 我服,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前台Vue使用axios实现文件下载功能,巨坑,一个简单的下载用了一天多才弄出来 我服

问题:
项目框架用的是springcloud+vue前后端分离的项目,登录用的是JWT,基于token的登录;然后header中存储token来实现登录
问题1:
网上很多方式都是通过这种方式来的,如果不需要获取header中信息的话,通过这种方式也是可以的。
通过: window.location.href="http://127.0.0.1:8088/server/invoice/downFile“;
登录会发现,一直提示登录失败,查看才知道这种方式,把header中的信息丢失了,所以token一直获取不到
问题2:
通过axios像普通的发送axios请求,发现下载没有任何反应,一直找不到原因。

纠结了一天半,终于解决了

后来是通过这种方式来实现的

1.普通的下载,已知下载路径和下载文件的:
div中:一个按钮

    <el-buttontype="primary"@click="uploadFile"><i class="el-icon-upload el-icon--right"></i>导出</el-button>

methods中,必须写两个方法:

 //下载指定路径的文件uploadFileExcel() {var self = thisthis.$axios({method: 'get',url: '/api/groupApi/group/importAPINew',responseType: 'blob'}).then(function (response) {console.log(response);self.downloadFile(response.data);})},downloadFile(data) {// 文件导出if (!data) {return}let url = window.URL.createObjectURL(new Blob([data]));let link = document.createElement('a');link.style.display = 'none';link.href = url;//文件名link.setAttribute('download', 'api_.yaml');document.body.appendChild(link);link.click()},

后台代码:

   @GetMapping("importAPINew")public void importAPINew(HttpServletResponse response, HttpServletRequest request) {String projectRealPath = null;try {//获取项目的相对路径projectRealPath = ResourceUtils.getURL("classpath:").getPath();} catch (FileNotFoundException e) {e.printStackTrace();}String newFilePath = projectRealPath + "/" +"api_2020-11-20_09_37_09.yaml";//调用下载方法即可FileDownLoadUtil.downloadFile(request,response,newFilePath,"api_2020-11-20_09_37_09.yaml");}

完毕
通过a标签的:
div:

 <el-link  type="primary" :underline="false"  @click="importAPI(scope.$index, scope.row)">API导出</el-link>

methods:

  //导出APIimportAPI(index,row) {console.log(row)this.apiGroup = row;var self = thisconsole.log(this.apiGroup.groupId)this.$axios({method: 'get',url: '/api/groupApi/group/importAPI',params:  {groupId : row.groupId},responseType: 'blob'}).then(function (response) {console.log(response);self.downloadFile(response.data);})},downloadFile(data) {// 文件导出if (!data) {return}let url = window.URL.createObjectURL(new Blob([data]));let link = document.createElement('a');link.style.display = 'none';link.href = url;link.setAttribute('download', 'api_.yaml');document.body.appendChild(link);link.click()},

后台代码:

 @GetMapping("importAPI")public void importAPI(Integer  groupId, HttpServletResponse response, HttpServletRequest request) {//根据相应的规则下载即可 导出Excel,或者xml文件等 就和普通下载一样了groupService.importAPI(groupId,response,request);}

完毕

这篇关于前台Vue使用axios实现文件下载功能,巨坑,一个简单的下载用了一天多才弄出来 我服的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3