如何实现后端返回excel文件,在前端下载功能

ops/2024/12/15 20:47:48/

前言

简单记录一下,excel文件导出下载功能

excel_9">一、后端接口返回excel文件

把自己生成的workbook 以文件流的方式,返回前台

Workbook workbook = employeeConfirmationDefectService.exportPoorPolishExcel(budatBegin, budatEnd, queryWrapper);//传输到前端下载try {response.setHeader("content-Type", "application/vnd.ms-excel");response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("抛光不良记录.xlsx", "UTF-8"));workbook.write(response.getOutputStream());workbook.close();} catch (IOException e) {throw new RuntimeException(e);}

二、前端接受文件流,下载文件

发送post请求,设定responseType: ‘blob’,指定响应数据为文件对象

export function postExcelExport(url,parameter) {let sign = signMd5Utils.getSign(url, parameter);//将签名和时间戳,添加在请求接口 Headerlet signHeader = {"X-Sign": sign,"X-TIMESTAMP": signMd5Utils.getDateTimeToString()};return axios({url: url,method:'post' ,params: parameter,headers: signHeader,responseType: 'blob'})
}

调用导出方法,发送请求

//导出下载excel文件
handleExportXls() {this.loading = truepostExcelExport(this.url.export, this.queryParam).then((data) => {console.log(data)if (!data) {this.$message.warning('文件下载失败')return}if (typeof window.navigator.msSaveBlob !== 'undefined') {window.navigator.msSaveBlob(new Blob([data], { type: 'application/vnd.ms-excel;charset=utf8' }),'文件名' + '.xls')} else {let url = window.URL.createObjectURL(new Blob([data], { type: 'application/vnd.ms-excel;charset=utf8' }))let link = document.createElement('a')link.style.display = 'none'link.href = urllink.setAttribute('download', '文件名' + '.xls')document.body.appendChild(link)link.click()document.body.removeChild(link) //下载完成移除元素window.URL.revokeObjectURL(url) //释放掉blob对象}}).finally(() => {this.loading = false})},

http://www.ppmy.cn/ops/142204.html

相关文章

触想工业一体机为高速公路远程供电提供稳定保障

一、行业应用概述 放眼高速公路沿线场景,常常会看到许多外场设备,比如摄像头、气象仪、情报板、ETC门架等,这些设备的应用都离不开电力支撑。 △ 高速公路外场设备 然而,随着高速里程越来越长,在远离市电的情况下&…

数据仓库工具箱—读书笔记01(数据仓库、商业智能及维度建模初步)

数据仓库、商业智能及维度建模初步 记录一下读《数据仓库工具箱》时的思考,摘录一些书中关于维度建模比较重要的思想与大家分享🤣🤣🤣 博主在这里先把这本书"变薄"~有时间的小伙伴可以亲自再读一读,感受一下…

MFC学习笔记专栏开篇语

MFC,是一个英文简写,全称为 Microsoft Foundation Class Library,中文翻译为微软基础类库。它是微软开发的一套C类库,是面向对象的函数库。 微软开发它,是为了给程序员提供方便,减少程序员的工作量。如果没…

陪玩系统小程序源码/游戏陪玩APP系统用户端有哪些功能?游戏陪玩小程序APP源码开发

多客陪玩系统-游戏陪玩线下预约上门服务等陪玩圈子陪玩社区系统源码 陪玩系统源码,高质量的陪玩系统源码,游戏陪玩APP源码开发,语音陪玩源码搭建: 线上陪玩活动组局与线下家政服务系统的部署需要综合考虑技术选型、开发流程、部署流程、功能实…

【c++线程库】

文章目录 线程创建方式mutex条件变量atomic 线程创建方式 头文件 #include<thread>线程创建传个可执行对象就可以&#xff0c;如函数指针&#xff0c;仿函数&#xff0c;lambda&#xff0c;包装器。后面的Args是可变参数包。 使用函数指针创建线程 void fun(int&…

抖音后端实习一面总结

置之死地而后生 抖音后端开发实习一面 自我介绍 你参加了PAT比赛&#xff1f;介绍一下&#xff1f; 平时有刷题吗&#xff1f;有的&#xff0c;那来做一下算法题目吧&#xff0c;单词拆分&#xff08;动态规划1h过去了...&#xff09; TCP有哪些状态&#xff1f;每种状态代表…

Android Compose 悬浮窗

今天需要写一个悬浮窗&#xff0c;但是在 Compose 中显示悬浮窗会遇到生命周期问题&#xff0c;我搜了一下&#xff0c;竟然有博主还要付费才给看&#xff0c;我真的是&#xff0c;开源社会不过是闻道有先后&#xff0c;大家互帮互助才有未来&#xff0c;这样明目张胆的放几张收…

【游戏设计原理】8 - 霍华德的隐匿性游戏设计法则

1. 霍华德的隐匿性游戏设计法则 霍华德的隐匿性游戏设计法则的核心思想是&#xff1a;“秘密的重要性与其表面上的无辜性和完整度成正比”。这意味着&#xff0c;当游戏开始时&#xff0c;设计上越是简洁、无害、直观的元素&#xff0c;隐藏的深层意义和转折就会显得更加震撼和…