当前位置: 首页 > news >正文

electron下载文件,弹窗选择下载路径,并通知下载进度

1:在window.js中 引入session 

import { app, BrowserWindow, ipcMain, dialog, shell, session } from 'electron';

2:发送下载请求

 // 在主进程监听渲染进程发送的 'start-download' 事件ipcMain.on('start-download', async (event, downloadUrl) => {let win = BrowserWindow.getAllWindows()[0];});

3:弹窗选择路径

 // 在主进程监听渲染进程发送的 'start-download' 事件ipcMain.on('start-download', async (event, downloadUrl) => {let win = BrowserWindow.getAllWindows()[0];const savePath = await dialog.showSaveDialog(win[0], {defaultPath: path.basename(downloadUrl), // 使用源文件名作为默认保存文件名});console.log(savePath.canceled, savePath.filePath);});

4:判断下载地址,如果存在就下载,并监听发送进度

 ipcMain.on('start-download', async (event, downloadUrl) => {let win = this.getAllWindows();const savePath = await dialog.showSaveDialog(win[0], {defaultPath: path.basename(downloadUrl), // 使用源文件名作为默认保存文件名});console.log(savePath.canceled, savePath.filePath);if (!savePath.canceled) {const ses = session.fromPartition('persist:my-session');// 先移除之前可能已经注册的监听器ses.removeAllListeners('will-download');ses.on('will-download', (event, item, webContents) => {let win = BrowserWindow.getAllWindows()[0];const fileName = item.getFilename();console.log(`开始下载: ${fileName}`);// const savePath = path.join('C:', 'Users', 'A', 'Downloads', fileName);item.setSavePath(savePath.filePath);win.webContents.send('download-started', { fileName });item.on('updated', (event, state) => {if (state === 'interrupted') {console.log('下载中断...');} else if (state === 'progressing') {if (item.isPaused()) {console.log('下载暂停...');} else {console.log(savePath.filePath,`下载进度: ${((item.getReceivedBytes() / item.getTotalBytes()) * 100).toFixed(2,)}%`,);}}});item.on('done', (event, state) => {if (state === 'completed') {console.log('文件下载完成!');win.webContents.send('download-success', fileName);} else {console.log('下载失败');}});});// 开始下载文件const downloadItem = ses.downloadURL(downloadUrl);}});

5:在preload.js中暴露下载以及通知操作

const { contextBridge, ipcRenderer } = require('electron');
var os = require('os');contextBridge.exposeInMainWorld('electronAPI', {downloadSuccess: (callback) =>ipcRenderer.on('download-success', (e, savePath) => callback(savePath)),downloadFailed: () => ipcRenderer.on('download-failed', (e) => callback(e)),onDownloadStarted: (url) => ipcRenderer.send('start-download', url),
});

6:在渲染进程中使用


//下载项目const downloadProject = () => {// const fileUrl = 'http://192.168.1.999:8/server/core.jar'; // 替换为实际的文件 URL// window.electronAPI.onDownloadStarted(fileUrl);};window.electronAPI.downloadSuccess((res) => {if (res) {console.log('success', '下载成功', `${res}下载成功,可在客户端首页打开。`);}});window.electronAPI.downloadFailed((res) => {if (res) {console.log('error', '下载失败', '当前模型提交终端,请排查问题后重试。');}});

7:文件流下载

 ipcMain.on('start-download', async (event, downloadUrl, fileName, Authorization) => {let win = this.getAllWindows();const savePath = await dialog.showSaveDialog(win[0], {defaultPath: fileName, // 使用源文件名作为默认保存文件名});if (!savePath.canceled && savePath.filePath) {let window = BrowserWindow.getAllWindows()[0];window.webContents.send('download-start', fileName, savePath.filePath);//文件流下载const filePath = savePath.filePath;const response = await axios.get(downloadUrl, {headers: {ContentType: 'application/x-www-form-urlencoded',Authorization,},responseType: 'stream',});const writer = fs.createWriteStream(filePath);response.data.pipe(writer);return new Promise((resolve, reject) => {writer.on('finish', () => {console.log('File downloaded successfully:', fs.existsSync(filePath));window.webContents.send('download-success', fileName, filePath);});writer.on('error', () => {window.webContents.send('download-failed');});});}});

相关文章:

electron下载文件,弹窗选择下载路径,并通知下载进度

1:在window.js中 引入session import { app, BrowserWindow, ipcMain, dialog, shell, session } from electron; 2:发送下载请求 // 在主进程监听渲染进程发送的 start-download 事件ipcMain.on(start-download, async (event, downloadUrl) > {l…...

【Docker】容器被停止/删除的方式及命令:全面解析与实践指南

文章目录 引言一、容器的生命周期二、停止容器的命令及方式1. docker stop 命令2. docker kill 命令3. docker pause 和 docker unpause 命令4. docker restart 命令 三、删除容器的命令及方式1. docker rm 命令2. docker container prune 命令3. docker rm 与 docker rmi 的区…...

线上就医全流程医药机构接入文档接口代码-医保就医接口php-demo版本

2025年2月18日11:28:03 国密算法开发库推荐 lpilp/guomi 我测试过php 7.2 - 8.0都可以兼容,如果有能力可以自己开发 目前已经开发了核心的接口的测试demo,并且封装了工具类直接写业务逻辑即可,并且已经有线上项目在使用,如果需要demo代码可…...

缓存三大问题及其解决方案

缓存三大问题及其解决方案 1. 前言 ​ 在现代系统架构中,缓存与数据库的结合使用是一种经典的设计模式。为了确保缓存中的数据与数据库中的数据保持一致,通常会给缓存数据设置一个过期时间。当系统接收到用户请求时,首先会访问缓存。如果缓…...

大语言模型常用微调与基于SFT微调DeepSeek R1指南

概述 大型语言模型(LLM,Large Language Model)的微调(Fine-tuning)是指在一个预训练模型的基础上,使用特定领域或任务的数据对模型进行进一步训练,以使其在该领域或任务上表现更好。微调是迁移…...

LabVIEW的吞雨测控系统

本案例介绍了一种基于LabVIEW开发的吞雨测控系统,该系统通过建模仿真分析不同控制器模式下的阶跃信号响应,从而选择了最适合的控制器。为了有效解决在控制流量过程中出现的振荡收敛和流量信号大扰动问题,系统采用了改进的积分分离PID算法&…...

redis基础命令

基于内存的数据存储系统 redis中数据以键值对存储的 键区分大小写 redis默认都是使用字符串存储数据 //启动服务 redis-server //连接客户端 redis-cli //连接客户端,--raw表示以原始的形式显示内容 redis-cli --rawset keyname valueget keynamedel keyname //…...

基于Java+SpringBoot+Vue的前后端分离的校园闲置物品交易网站

基于JavaSpringBootVue的前后端分离的校园闲置物品交易网站 前言 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN[新星计划]导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末附源码下载链接…...

K8s 证书认知(K8s Certificate Awareness)

K8s 证书认知 在谈起 Kubernetes 证书时,总感觉其涵盖的内容繁多,仿佛千头万绪,让人不知该从何处着手阐述。为了更好地理清思路,本文将对相关内容进行系统的梳理和记录。 1、证书及链路关系 Kubeadm部署的集群,K8s …...

前x-ai首席科学家karpathy的从零构建ChatGPT视频学习笔记--8000字长图文笔记预警(手打纯干货,通俗易懂)

2025.2.17晚上21:57看完了整个视频,作为一个ai专业的学生虽然每天都在用ai,但是对于其背后的原理却不是那么清楚,而卡帕西的这支视频却让我醍醐灌顶,而且全程听起来很舒服,没有知识强行进入脑子的痛感,在他…...

【智慧校园】分体空调节能监管:打造高效节能的学习环境

随着科技的飞速发展和生活品质的不断提升,人们对于家居和办公环境的舒适度与智能化要求也越来越高。分体空调集中控制系统作为一种先进的空调管理方式,正逐渐成为现代家庭和办公场所的标配,为用户带来更加便捷、高效和节能的空调使用体验。随…...

深度学习-1.简介

Deep Learning - Lecture 1 Introduction to Deep Learning 学习深度学习的动机什么是深度学习什么导致了深度学习的出现模型与理论的发展(软件部分)通用图形处理单元GPU的发展(硬件部分)CPU与GPU计算对比 GPU与CPU的理论FLOPS对…...

【Rust中级教程】1.10. 引用及内部可变性(简单回顾):引用、内部可变性、`Cell`类型及相关操作

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 这篇文章只对所有权进行简单回顾,想要看完整的所有权系统阐述见【Rust自学】专栏…...

Docker 安装和配置 Nginx 详细图文教程

🚀 作者主页: 有来技术 🔥 开源项目: youlai-mall ︱vue3-element-admin︱youlai-boot︱vue-uniapp-template 🌺 仓库主页: GitCode︱ Gitee ︱ Github 💖 欢迎点赞 👍 收藏 ⭐评论 …...

基于Java+Swing+Mysql实现旅游管理信息系统

基于JavaSwingMysql实现旅游管理信息系统 一、系统介绍二、功能展示1.登陆2.注册3.旅游信息查询4.查看游行团信息5.报名6、报名信息管理 三、数据库四、其它1.其他系统实现五.获取源码 一、系统介绍 用户:登陆、注册、旅游信息查询、查看游行团信息、报名 管理员&a…...

使用 Openpyxl 操作 Excel 文件详解

文章目录 安装安装Python3安装 openpyxl 基础操作1. 引入2. 创建工作簿和工作表3. 写入数据4. 保存工作簿5. 加载已存在的Excel6. 读取单元格的值7. 选择工作表 样式和格式化1. 引入2. 设置字体3. 设置边框4. 填充5. 设置数字格式6. 数据验证7. 公式操作 性能优化1. read_only/…...

统信服务器操作系统V20 1070A 安装docker新版本26.1.4

应用场景: 硬件/整机信息:x86平台、深信服超融合平台 OS版本信息:统信V20 1070a 1.获取docker二进制包 链接: https://pan.baidu.com/s/1SukBlra0mQxvslTfFakzGw?pwd5s5y 提取码: 5s5y tar xvf docker-26.1.4.tgz groupadd docker ch…...

【数据分享】1929-2024年全球站点的逐年降雪深度数据(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据,气象指标包括气温、风速、降水、能见度等指标,说到气象数据,最详细的气象数据是具体到气象监测站点的数据! 有关气象指标的监测站点数据,之前我们分享过1929-2024年全球气象站…...

python爬虫系列课程1:初识爬虫

python爬虫系列课程1:初识爬虫 一、爬虫的概念二、通用爬虫和自定义爬虫的区别三、开发语言四、爬虫流程一、爬虫的概念 网络爬虫(又被称为网页蜘蛛、网络机器人)就是模拟浏览器发送网络请求,接收请求响应,一种按照一定的规则,自动抓取互联网信息的程序。原则上,只要是…...

大模型工具大比拼:SGLang、Ollama、VLLM、LLaMA.cpp 如何选择?

简介:在人工智能飞速发展的今天,大模型已经成为推动技术革新的核心力量。无论是智能客服、内容创作,还是科研辅助、代码生成,大模型的身影无处不在。然而,面对市场上琳琅满目的工具,如何挑选最适合自己的那…...

Cursor Pro破解工具:如何永久免费使用AI编程助手?

Cursor Pro破解工具:如何永久免费使用AI编程助手? 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached y…...

Claude Code + CCR + AWS Bedrock 踩坑复盘:上下文超限、模型路由、Mantle 端点与 Qwen3 Coder Next

最近在使用 Claude Code Claude Code Router(CCR) AWS Bedrock 模型 做代码开发时,遇到了一连串和上下文长度、模型路由、AWS 端点类型相关的问题。表面上看只是一个 context length exceeded 报错,实际排查下来牵扯到&#xff1…...

手把手教你用LabVIEW FPGA的Tick Count给代码‘掐表’:从测量循环周期到自定义高精度计时器

深入探索LabVIEW FPGA中的Tick Count:从性能分析到高精度定时器设计 在FPGA开发中,精确的时间控制与测量往往是项目成败的关键。当我们需要评估一段代码的执行效率、构建自定义定时逻辑或者实现精准的事件同步时,LabVIEW FPGA提供的Tick Coun…...

从美颜到元宇宙:3D Morphable Model如何悄悄改变你的数字生活?

从美颜到元宇宙:3D Morphable Model如何悄悄改变你的数字生活? 当你打开手机里的美颜App,滑动捏脸参数时,是否想过屏幕背后是一套怎样的技术在支撑?当你在电商平台试戴虚拟眼镜,或在游戏中创建专属虚拟形象…...

.NET 9跨平台边缘部署实战手册(ARM64/Windows IoT/Linux RT全栈适配大揭秘)

更多请点击: https://intelliparadigm.com 第一章:.NET 9跨平台边缘部署全景概览 .NET 9 正式引入原生 AOT(Ahead-of-Time)编译的生产级支持与轻量级容器运行时优化,显著降低边缘设备资源占用。其跨平台能力已覆盖 Li…...

3步释放C盘空间:FreeMove让Windows目录迁移变得安全又简单

3步释放C盘空间:FreeMove让Windows目录迁移变得安全又简单 【免费下载链接】FreeMove Move directories without breaking shortcuts or installations 项目地址: https://gitcode.com/gh_mirrors/fr/FreeMove 你是否曾经因为C盘空间不足而苦恼?那…...

第四章:TTM分析: 4.5.1 ttm_device对三大设计目标的实现

2. 统一管理异构内存域 这是 ttm_device 最基础的职责:将 VRAM、GTT、SYSTEM 等物理上完全不同的内存,纳入统一的管理框架。 2.1 资源管理器数组 man_drv[] struct ttm_resource_manager *man_drv[TTM_NUM_MEM_TYPES];这是一个按内存域类型索引的指针…...

real-anime-z快速上手指南:无需代码,通过WebUI生成高质量动漫图

real-anime-z快速上手指南:无需代码,通过WebUI生成高质量动漫图 1. 模型简介 real-anime-z是基于Z-Image的LoRA版本开发的文生图模型,专注于生成高质量的动漫风格图片。这个模型通过Xinference部署,并提供了基于Gradio的WebUI界…...

【Matlab】MATLAB教程:MATLAB与C语言交互实操(mex编译C代码案例+代码计算效率提升实战应用)

MATLAB教程:MATLAB与C语言交互实操(mex编译C代码案例+代码计算效率提升实战应用) 本教程适配MATLAB全系列Windows及Linux通用版本,依托MATLAB原生MEX编译交互机制开发,无需付费专业工具箱,仅需配置基础C语言编译环境即可快速部署使用,专为MATLAB数值仿真从业者、工程迭…...

AIGC工具平台-TTS通用文本转语音

课程讲解、短视频旁白和批量内容生产都需要稳定配音,手工录制成本高,也难以保持语速和音色一致。 TTS 用于把文本生成语音,支持服务商配置、音色参数、单次生成、批量处理、播放预览和任务记录。 文章目录模块定位项目配置项目说明配置管理单…...