electron暴露配置文件(用户可随时修改)
配置文件
一般web前端项目配置文件,写死的放在src/config
下,需要打包配置的放在.env
文件中。但在electron项目中,如果配置数据更改,需要每次给用户打包升级肯定是行不通的。于是外部配置文件就是有必要的,具体实现方法也比较简单,通过fs
去读写外部文件就可实现
具体实现
设置文件不被压缩混淆
将配置文件放在根目录的config
文件夹
配置electron- builder文件,我这里是yml配置
...
productName: xxx
asarUnpack:
- resources/**
extraResources:
- ./config
...
在extraResources
属性添加文件夹名称
打包后路径为/resources/config/...
可以打包后查看
获取路径
process.cwd()
此时获取是node服务的根路径,再拼接上本地文件的路径
dev环境为项目根目录
prod环境为安装后文件夹路径
const path = process.cwd()
const filePath = is.dev
? join(path, '/config/app.properties')
: join(path, '/resources/config/app.properties')
读写文件
这里用到了fs
、path
、ini
等node模块,所以不可以在renderer里面操作,要通过主进程handle通信到渲染进程获取
npm i ini
class ConfigHandle {
private getConfig(_: IpcMainInvokeEvent) {
return new Promise((resolve, reject) => {
fs.readFile(filePath, 'utf8', function (err, dataStr) {
if (err) {
return reject(err.message)
}
resolve(ini.parse(dataStr.toString()))
})
})
}
private setConfig(_: IpcMainInvokeEvent, config) {
return new Promise((resolve, reject) => {
fs.readFile(filePath, 'utf8', function (err, dataStr) {
if (err) {
return reject(err.message)
}
const origin = ini.parse(dataStr.toString())
// 这里做了先读取再assign操作,不会全量覆盖
fs.writeFile(filePath, ini.stringify(Object.assign(origin, config)), function (err) {
if (err) {
return reject(err.message)
}
resolve('success')
})
})
})
}
register() {
ipcMain.handle('get-config', this.getConfig)
ipcMain.handle('set-config', this.setConfig)
}
}
通信到renderer
- main
configHandle.register()
- preload
const api = {
config: {
get: () => ipcRenderer.invoke('get-config'),
set: (config: object) => ipcRenderer.invoke('set-config', config)
}
}
contextBridge.exposeInMainWorld('api', api)
- renderer
export const config = await window.api.config.get()
export const setConfig = config => window.api.config.set(config)
const baseUrl = config.baseUrl
setConfig({baseUrl: "http://xxx"})
这样可以通过程序修改配置文件,或者用户自己编辑修改配置文件
- config/app.properties
title=good title
baseUrl=great url
defaultPassword=unbelievable pwd
通过ini.parse
会转成json格式,非常方便
分类:
electron
标签:
JavaScript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!