node.js - 在ElectronJS(Asar)中编写JSON文件

标签 node.js json electron fs electron-packager

问题FrameWork - ElectronJS我的程序使用.json文件保存用户输入的数据。在开发环境中,这些文件编写得很完美,但是用electron-packager打包后,不再写入JSON文件,这完全使我的程序无效。
我主要使用那些JSON文件来编写程序,因此完全删除它们将再次从头开始编写程序。有没有办法像在开发环境中那样使程序在客户端PC中写入JSON文件。
样例程序
这只是一个示例程序,但是我所有的代码都是这种格式。

//JavaScript 

//This Javascript catches user inputs and send them to jsonWriter function


document.getElementById("save").addEventListener('click', async function(e) {
  e.preventDefault()

  var userData = document.getElementById('username').value
  var acctData = document.getElementById('account').value

  var formData = {
    username: userData,
    account: acctData
  }; // create JS object

  await writer.jsonLC(formData);
});


// This is my json Writer function

async function jsonForAuth(data){

    let element = JSON.stringify(data);
    fs.writeFileSync(__dirname + '\\data\\auth.json', element) 

//All my directory for 'fs' are written in such format with a '__dirname'

}

module.exports.jsonLC = jsonForAuth;

// All of this works perfectly on dev-environment (VS-Code)
现在我用electron-packager打包
// Here is my package.json for reference

{
  "name": "electron_app",
  "productName": "Test App",
  "version": "1.0.0",
  "description": "",
  "main": "main.js",
  "dependencies": {
    "asar": "^3.0.3",
    "axios": "^0.20.0",
    "fs-extra": "^9.0.1",
    "jwt-decode": "^3.0.0-beta.2",
    "keytar": "^6.0.1",
    "node-fetch": "^2.6.1",
    "puppeteer-core": "^5.3.0"
  },
  "devDependencies": {
    "electron": "^10.1.2",
    "electron-packager": "^15.1.0"
  },
  "scripts": {
    "start": "electron .",
    "package-mac": "electron-packager . --overwrite --platform=darwin --arch=x64 --icon=assets/icons/mac/icon.icns --prune=true --out=release-builds",
    "package-win": "electron-packager . electron_app --overwrite --asar --platform=win32 --arch=x64 --icon=assets/img/icons/win/icon.ico --prune=true --out=release-builds --version-string.CompanyName=CE --version-string.FileDescription=CE --version-string.ProductName=\"Test App\"",
    "package-linux": "electron-packager . electron-tutorial-app --overwrite --asar=true --platform=linux --arch=x64 --icon=assets/icons/png/1024x1024.png --prune=true --out=release-builds"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

包装代码与This guide here完全相同。
结论
现在,在打包应用程序和一些不需要json files的脚本后,它们可以正常工作。但是现在,由于不再创建json文件,上面的sample program变得无用了。
**如何进行这项工作? **Note: I have NOT used ipcRenderer() anywhere in my program.更新
我发现asar是只读文件。
那么有没有办法将我的json保存位置的位置更改为Local/Appdata?
谢谢,如果解释太大,我们很抱歉。

最佳答案

是的,写入应用程序位置不是一个好主意,并且经常被禁止。使用通常用于应用程序设置等的appdata文件夹应该足够了。
app.getPath(name) 是您要寻找的功能。
然后执行以下操作:

fs.writeFileSync(app.getPath("appData") + "/auth.json", element);
甚至更好,使用 path :
fs.writeFileSync(path.join(app.getPath("appData"), "auth.json"), element);

关于node.js - 在ElectronJS(Asar)中编写JSON文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64152400/

相关文章:

javascript - 包含的帮助程序类上的 Node 引用错误

python - 无法从 Cherrypy 将日期时间序列化为 JSON

c# - JSON 字符串解析错误。 System.Exception {Newtonsoft.Json.JsonReaderException}

javascript - 如何检查我的 Bokeh 服务器应用程序是否已完全加载和呈现?

javascript - 'ReadableStream<any>' 类型的参数不可分配给 'ReadableStream' 类型的参数

javascript - 将数组从 js 传递到 Nodejs

javascript - 实时 API 后端和前端

json - 在配置单元脚本中使用 json_tuple 语法时发生错误

javascript - 从 Electron 主线程运行批处理文件

vue.js - 即使响应为 200(成功)也会调用 Axios Catch