前端下载时,出现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

相关文章

Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法

《Java报错:org.springframework.beans.factory.BeanCreationException的五种解决方法》本文解析Spring框架中BeanCreationExce... 目录引言一、问题描述1.1 报错示例假设我们有一个简单的Java类,代表一个用户信息的实体类:然后,

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动