前端封装通用下载方法及下载后端返回的文件流

目录

1.下载方法封装

2.将后端返回的文件流转换为文件

3.总结


1.下载方法封装

①说明

前端的请求大概分为三种类型

普通请求:常用的get,post,put,delete等请求

上传请求:使用post请求,发送formdata对象的参数,formdata中存放文件及其他参数

下载请求:使用post请求,设置响应格式为blob或者arraybuffer

②通用下载请求说明

api:

// 共通下载方法
export function dowload(url:string,params:any,filename:string,config:any) {return  axios.post(url,params,{    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },responseType: 'blob',...config}).then((data:any) =>{if(data.type !== 'application/json'){const blob = new Blob([data],{ type: 'application/vnd.ms-excel' })saveAs(blob,filename)// let objectUrl = URL.createObjectURL(blob) // 创建URL// let link = document.createElement("a");// link.href = objectUrl// link.download =filename // 自定义文件名// link.click() // 下载文件// URL.revokeObjectURL(objectUrl); // 释放内存}}).catch((r:any) =>{console.log(r)Message.error({ content: '下载文件出现错误,请联系管理员!', position: 'top' });})}

说明:

前端下载后端的文件,一般分为两种类型,后端返回文件流或者后端将文件存储在服务器,将地址返回至前端。

我使用的是后端返回文件流的方式,前端的请求需要将responseType设置为blob格式,代表后端返回的是二进制文件流。content-type按照需要进行设置,可以设置为application/x-www-form-urlencoded或者application/json,不同的方式决定了后端接收参数的方式不一样。

拦截器设置:

axios.interceptors.response.use((response: AxiosResponse<any>) => {// 二进制数据则直接返回if (response.request.responseType === 'blob') {return response.data}const res = response.data;let resCode = res.resHdr?.resCode;let resMsg = res.resHdr?.resMsg || "请求未知异常";if (resCode == "9990_10" || resCode == "9990_9") {Message.error({content: "登录信息过期,请重新登录",duration: 5 * 1000,});// 跳转登录页面router.push("/login");return Promise.reject(new Error(resMsg));}if (resCode !== "0000") {Message.error({content: resMsg,duration: 5 * 1000,});return Promise.reject(new Error(resMsg));}return res.resBody;},(error) => {Message.error({content: error.msg || "请求未知异常",duration: 5 * 1000,});return Promise.reject(error);}
);

说明:

响应拦截器中要对responseType进行判断,如果是blob格式的,直接返回response中的data,其他格式时,一般为json,需要获取返回的data的返回值进行判断,登录过期时跳转到登录画面,并进行信息提示,异常时进行信息提示,正常时返回data,然后在接口中对data的内容进行处理。

2.将后端返回的文件流转换为文件

在通过下载方法中,获取到返回的data数据,需要将数据流转为文件。

方式1:

// 共通下载方法
export function dowload(url:string,params:any,filename:string,config:any) {return  axios.post(url,params,{    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },responseType: 'blob',...config}).then((data:any) =>{if(data.type !== 'application/json'){const blob = new Blob([data],{ type: 'application/vnd.ms-excel' })let objectUrl = URL.createObjectURL(blob) // 创建URLlet link = document.createElement("a");link.href = objectUrllink.download =filename // 自定义文件名link.click() // 下载文件URL.revokeObjectURL(objectUrl); // 释放内存}}).catch((r:any) =>{console.log(r)Message.error({ content: '下载文件出现错误,请联系管理员!', position: 'top' });})}

 将data转换为blob对象,然后根据blob创建url,再创建一个a元素,将a元素的href属性和url进行绑定,再设置下载的文件名,触发click事件进行下载。

方式2:

使用file-saver方式

①安装依赖:

pnpm install file-saver --savepnpm install @types/file-saver --save-dev

②使用

import { saveAs } from 'file-saver'// 共通下载方法
export function dowload(url:string,params:any,filename:string,config:any) {return  axios.post(url,params,{    headers: { 'Content-Type': 'application/x-www-form-urlencoded' },responseType: 'blob',...config}).then((data:any) =>{if(data.type !== 'application/json'){const blob = new Blob([data],{ type: 'application/vnd.ms-excel' })saveAs(blob,filename)}}).catch((r:any) =>{console.log(r)Message.error({ content: '下载文件出现错误,请联系管理员!', position: 'top' });})}

 调用saveAs方式,传递blob对象及文件名即可

3.总结

注意通过下载方法的封装

注意响应拦截器首先要对响应类型进行判断,blob格式直接返回data

生成文件直接使用file-saver方式,比较方便

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/713784.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Zookeeper学习1:概述、安装、应用场景、集群配置

文章目录 概述安装LinuxWindows 配置参数集群参考配置文件配置步骤流程启动 概述 Zookeeper&#xff1a; 为分布式框架组件提供协调服务的中间件 【类似&#xff1a;文件系统通知机制】 负责存储上下层应用关系的数据以及接收观察者注册监听&#xff0c;一旦观察查关心的数据发…

git操作基本指令

1.查看用户名 git config user.name 2.查看密码 git config user.password 3.查看邮箱 git config user.email 4.修改用户名 git config --global user.name "xxx(新用户名)" 5.修改密码 git config --global user.password "xxx(新密码)" 6.修改…

笔记73:ROS中的各种消息包

参考视频&#xff1a; 33.ROS 的标准消息包 std_msgs_哔哩哔哩_bilibili 34. ROS 中的几何包 geometry_msgs 和 传感器包 sensor_msgs_哔哩哔哩_bilibili 标准消息包&#xff1a;std_msgs常用消息包&#xff1a;common_msgs导航消息包&#xff1a;nav_msgs几何消息包&#xf…

实战分享:Tomcat打破双亲委派模型,实现Web应用独立与安全隔离的奥秘

目录 一、JVM 类加载机制 二、Tomcat 类加载器 2.2 findClass 介绍 3.2 loadClass 介绍 三、web应用隔离 3.1 Spring 加载问题 在开始文章内容之前&#xff0c;先来看三个问题 假如在 Tomcat 上运行了两个 Web 应用程序&#xff0c;两个 web 应用中有同名的Servlet&#xf…

C++数据结构与算法——二叉树的属性

C第二阶段——数据结构和算法&#xff0c;之前学过一点点数据结构&#xff0c;当时是基于Python来学习的&#xff0c;现在基于C查漏补缺&#xff0c;尤其是树的部分。这一部分计划一个月&#xff0c;主要利用代码随想录来学习&#xff0c;刷题使用力扣网站&#xff0c;不定时更…

AGI概念与实现

AGI AGI&#xff08;Artificial General Intelligence&#xff09;&#xff0c;中文名为“通用人工智能”或“强人工智能”&#xff0c;是指通过机器学习和数据分析等技术&#xff0c;使计算机具有类似于人类的认知和学习能力的技术. 多模态的大模型 &#xff08;Multimodal…

详细介绍如何用windows自带Hyper-V安装虚拟机(windows11和ubuntu22)

通过系统自带的hyper-v安装windows11&#xff0c;舒服又惬意&#xff0c;相比用第三方虚拟机软件速度快很多。 硬件准备 准备 系统需要符合能安装 Hyper-V 的最低要求windows版本含Hyper-V的功能 电脑空间 电脑要有足够的空间来安装你这个虚拟机。根据自己的磁盘容量情况来规…

2673. 使二叉树所有路径值相等的最小代价

给你一个整数 n 表示一棵 满二叉树 里面节点的数目&#xff0c;节点编号从 1 到 n 。根节点编号为 1 &#xff0c;树中每个非叶子节点 i 都有两个孩子&#xff0c;分别是左孩子 2 * i 和右孩子 2 * i 1 。 树中每个节点都有一个值&#xff0c;用下标从 0 开始、长度为 n 的整…

CloudCanal x Hive 构建高效的实时数仓

简述 CloudCanal 最近对于全周期数据流动进行了初步探索&#xff0c;打通了Hive 目标端的实时同步&#xff0c;为实时数仓的构建提供了支持&#xff0c;这篇文章简要做下分享。 基于临时表的增量合并方式基于 HDFS 文件写入方式临时表统一 Schema任务级的临时表 基于临时表的…

【Linux实践室】Linux初体验

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;Linux实践室、网络奇遇记 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 一. ⛳️任务描述二. ⛳️相关知识2.1 &#x1f514;Linux 目录结构介绍2.2 &#x1f514;Linux …

WebFlux相关问题及答案(2024)

1、什么是Spring WebFlux&#xff1f; Spring WebFlux 是 Spring Framework 5.0 中引入的一个全新的反应式框架&#xff0c;用于构建异步、非阻塞且事件驱动的服务。它允许开发者使用响应式编程模型来处理并发性很高的操作&#xff0c;而无需担心传统的多线程环境中的复杂性。…

poi工具读写excel操作学习总结

写在前面的话 POI作为比较早期的Excel处理工具&#xff0c;其使用较为成熟且广泛。EasyExcel相较之下&#xff0c;则是相对较新的工具&#xff0c;其却有着比POI更为优越的一些特性&#xff0c;如更加简单的API接口和更加优秀的性能。 性能对比&#xff1a;在数据量较小的情况下…

mybatis mysql insert 主键id为空

错误示范 java代码设置了param参数&#xff0c;但是sql 字段没有带上参数&#xff0c;例如 void insertV2(Param("historyDO") HistoryDO historyDO); <insert id"insertDuplicate" parameterType"com.test.entity.HistoryDO"keyProperty&…

MySQL:一行记录如何

1、表空间文件结构 表空间由段「segment」、区「extent」、页「page」、行「row」组成&#xff0c;InnoDB存储引擎的逻辑存储结构大致如下图&#xff1a; 行 数据库表中的记录都是按「行」进行存放的&#xff0c;每行记录根据不同的行格式&#xff0c;有不同的存储结构。 页…

hippy 调试demo运行联调-mac环境准备篇

适用对于终端编译环境不熟悉的人看&#xff0c;仅mac端 hippy 调试文档官网地址 前提&#xff1a;请使用node16 联调预览效果图&#xff1a; 编译iOS Demo环境准备 未跑通&#xff0c;待补充 编译Android Demo环境准备 1、正常安装Android Studio 2、下载Android NDK&a…

Windows系统误删文件恢复

最近很多用户反馈误删文件的场景比较多.下面华仔将讲解数据恢复的原理和过程.以及一些注意事项。 建议的数据恢复软件 1.EaseUS Data Recovery Wizard(易我数据恢复)需要断网使用 2.Wondershare Recoverit(万兴数据恢复)&#xff0c; Windows系统删除文件原理&#xff1a;如果是…

Android ShellUtils手机管理器

1. Android ShellUtils手机管理器 Android Shell工具类&#xff0c;可用于检查系统root权限&#xff0c;并在shell或root用户下执行shell命令。如&#xff1a; checkRootPermission() 检查root权限 。execCommand(String[] commands, boolean isRoot, boolean isNeedResultMsg)…

HTTPS是什么,详解它的加密过程

目录 1.前言 2.两种加密解密方式 2.1对称加密 2.2非对称加密 3.HTTPS的加密过程 3.1针对明文的对称加密 3.2针对密钥的非对称加密 3.3证书的作用 1.前言 我们知道HTTP协议是超文本传输协议,它被广泛的应用在客户端服务器上,用来传输文字,图片,视频,js,html等.但是这种传…

java数据结构与算法刷题-----LeetCode572. 另一棵树的子树(经典题,树字符串化KMP)

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 1. 暴力求解&#xff0c;深度优先2. KMP算法进行串匹配 1. 暴力求…

WinForm、Wpf自动升级 AutoUpdater.NET

Github AutoUpdater.NET 目录 一、IIS部署 更新站点 二、创建Winform 一、IIS部署 更新站点 IIS默认站点目录下创建 目录 Downloads、Updates Updates目录创建文件 UpdateLog.html、AutoUpdaterStarter.xml UpdateLog.html&#xff1a; <html><body><h1…