Linux下Electron loadURL报错 ERR_FAILED(-2) Not allowed to load local resource
Linux下Electron loadURL报错 ERR_FAILED(-2) Not allowed to load local resource
背景
使用electron-vue的时候,窗体创建后加载页面使用的是loadURL
函数,并且传入的参数形如:
`file://${__dirname}/index.html`
PS:在electron-vue中,编译打包后的__dirname
是asar所在绝对地址/dist/electron/
。
编译打包后的Electron程序启动时候,发现在调用loadURL的时候会出现:ERR_FAILED(-2) 。
遂临时启动DevTool窗口查看控制台输出,发现类似如下错误:
Not allowed to load local resource: file://XXXXXX/app.asar/dir1/dir2/index.html
原因及方案
1、文件并不存在于你的asar包中
处理方式:
- 全局安装
npm install -g asar
- 通过asar解压app.asar包,检查上述提到的file路径中是否存在你的index.html。
2、尝试禁用窗体参数中的webSercurity
处理方式:
{
webPreferences: {
webSecurity: false
}
}
3、检查webpack配置中的__dirname,防止webpack处理'mock'
这一点主要是当上述Not alloed to load local resource
提到的路径明显不正确时候,可以检查。
// webpack配置文件中的node节点,当打包的时候需要防止webpack处理
node: {
__dirname: false
}
webpack配置文件中的node节点,当打包的时候需要防止webpack处理__dirname
,如果你使用了electron-vue脚手架应该不需要关心,因为你会看到如下的内容,已经帮你处理了:
node: {
__dirname: process.env.NODE_ENV !== 'production',
__filename: process.env.NODE_ENV !== 'production'
},
4、使用loadFile而不是loadURL
使用loadFile接口来加载本地的路径,loadFile('path/to/index.html'),这个路径是以app.asar根路径为base的。例如,loadFile('dir_path1/dir_path2/index.html'),那么你的index.html在app.asar是如下的结构:
app.asar
|-dir_path1
|-dir_path2
|-index.html
5、确定file协议斜杆正确
本人在编写代码的时候,由于马虎,loadURL的参数想要加载本地的页面,file:/XXX
少写了一个斜杠,应该是file://
,导致加载问题。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!