electron 本地文件管理系统关于下载的一个关键点

项目场景:

提示:这里简述项目相关背景:

前提是下载一个很大 几个G甚至几十个G的文件 设想是在nodejs里负责创建文件夹和下载


问题描述

提示:这里描述项目中遇到的问题:

通过 axios模块进行下载,但报了

The provided value 'stream' is not a valid enum value of type XMLHttpRequestResponseType.

c 复制代码
		const response = await axios({
            url: file_url,
            method: 'GET',
            timeout: 0,
            responseType: 'stream'
        });

原因分析:

提示:这里填写问题的分析:

超时 不管怎样都捕捉不到错误 下载进度也获取不到 只能捕获超时的错误 因为文件过大 还不能设置超时 所以等于完全无反应的,所以就先从请求头入手 调试发现跟请求头无关 试了一堆一堆的方式 掠过 直接说解决方案

解决方案:

本来node.js是通过

typescript 复制代码
webPreferences: {
      allowRunningInsecureContent: true,
      webSecurity: false,
      preload: path.join(__dirname, "preload.js"),
},

主入口文件里加载preload.js 脚本主要用于在渲染进程和主进程之间建立安全的通信桥梁,它的运行环境比较特殊,更接近浏览器环境,这就可能导致 axios 基于 XMLHttpRequest 来处理请求,从而出现不支持 'stream' 响应类型的错误。

把微服务部署位置放在

typescript 复制代码
app.whenReady().then(() => {
    startHttpServe()
    createWindow();

    app.on("activate", () => {
      if (BrowserWindow.getAllWindows().length === 0) createWindow();
    });
  });

就好了
app.whenReady() 是在 Electron 主进程里执行的,主进程本质上就是一个 Node.js 进程,在这个环境下 axios 基于 http 和 https 模块实现,能够很好地支持 'stream' 响应类型,所以把代码放到这里执行就没问题了。

相关推荐
疯狂的沙粒20 分钟前
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
前端·uni-app·html
小妖66623 分钟前
html 滚动条滚动过快会留下边框线
前端·html
heroboyluck38 分钟前
Svelte 核心语法详解:Vue/React 开发者如何快速上手?
前端·svelte
海的诗篇_39 分钟前
前端开发面试题总结-JavaScript篇(二)
开发语言·前端·javascript·typescript
琹箐1 小时前
ant-design4.xx实现数字输入框; 某些输入法数字需要连续输入两次才显示
前端·javascript·anti-design-vue
程序员-小李1 小时前
VuePress完美整合Toast消息提示
前端·javascript·vue.js
Uyker2 小时前
从零开始制作小程序简单概述
前端·微信小程序·小程序
Dontla5 小时前
为什么React列表项需要key?(React key)(稳定的唯一标识key有助于React虚拟DOM优化重绘大型列表)
javascript·react.js·ecmascript
EndingCoder6 小时前
React从基础入门到高级实战:React 实战项目 - 项目三:实时聊天应用
前端·react.js·架构·前端框架
阿阳微客7 小时前
Steam 搬砖项目深度拆解:从抵触到真香的转型之路
前端·笔记·学习·游戏