前台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

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

PyQt6/PySide6中QTableView类的实现

《PyQt6/PySide6中QTableView类的实现》本文主要介绍了PyQt6/PySide6中QTableView类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录1. 基本概念2. 创建 QTableView 实例3. QTableView 的常用属性和方法

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

PyQt6/PySide6中QTreeView类的实现

《PyQt6/PySide6中QTreeView类的实现》QTreeView是PyQt6或PySide6库中用于显示分层数据的控件,本文主要介绍了PyQt6/PySide6中QTreeView类的实现... 目录1. 基本概念2. 创建 QTreeView 实例3. QTreeView 的常用属性和方法属性

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型