前端下载时,出现err::netERR_FAULT的报错

2024-08-28 12:04

本文主要是介绍前端下载时,出现err::netERR_FAULT的报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

场景:文件下载时,前端通过axios请求后台接口,同时将文件的“半链接”传给该接口,此时后台会重定到文件下载的链接,如果文件过大时,部分浏览器则会出现上述报错,导致无法下载

解决方案:前端通过fetch请求该接口,然后获取到对应的重定向链接,然后通过前端下载即可

注意:在使用fetch请求时,要添加token

下边直接上代码

问题代码:

// 下载全部模板
const downloadModel = async () => {const url = '/common/url'if (url ) {tempDownload(url , '全部模板.zip')} else {ElMessage.warning('模板不存在!')}
}// 前端下载方法
const tempDownload = async (url: string, fileName?: string) => {// 此处的接口,后台会发生重定向,导致部分浏览器在重定向时,产生报错const blob = await downloadPermission({ url })const a = document.createElement('a')a.style.display = 'none'const href = window.URL.createObjectURL(blob)a.href = hrefa.download = fileName ? fileName : 'file'document.body.appendChild(a);a.click();window.URL.revokeObjectURL(url);document.body.removeChild(a);
}

正确代码:

// 下载全部模板
const downloadModel = async () => {const url = '/common/url'const token = '系统token'if (url) {// 通过后台接口,获取可以下载的全链接,并且有权限、时效控制fetch(`/download/files?url=${url}`, {method: 'GET',headers: {"accept": "*/*",'Cache-Control': 'no-cache',"token": token ,}}).then((response) => {if (response.url) {// 前端通过tempDownload方法直接下载即可tempDownload(response.url, '全部模板.zip')} else {ElMessage.warning('模板不存在!')}}).catch(error => console.log('error', error))} else {ElMessage.warning('模板不存在!')}
}// 前端下载方法
const tempDownload = async (url: string, fileName?: string) => {if (!url) return falseconst a = document.createElement('a')a.style.display = 'none'a.href = urla.download = fileName ? fileName : 'file'document.body.appendChild(a)a.click() // 触发点击事件以启动下载document.body.removeChild(a)
}

这篇关于前端下载时,出现err::netERR_FAULT的报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

《Java下载文件中文文件名乱码的解决方案(文件名包含很多%)》Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath,UTF-8... 目录Java下载文件中文文件名乱码问题一般情况下,大家都是这样为了解决这个问题最终解决总结Java下

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...