服务器首次启动时,创建一次JSON文件

时间:2015-08-02 13:06:04

标签: javascript json node.js fs

我正在尝试创建一个json文件(服务器首次加载),以便稍后我可以引用该json文件,而不是每次用户请求该页面时都呈现该JSON文件。

我有一个有效的json。我用firefox和here检查了它,但是当我尝试使用node.js创建一个文件并且先前检查过JSON时,我收到错误。

首先我创建它运行的文件(并且它已被填充,但只有第一次使用新文件名,如果我再次使用相同的文件名,文件将为空...)并且只要我加载它,这个文件变空了,我得到了那个错误(实际上我不知道它何时变空,这是我的问题,我不知道错误在哪里......)。

错误:

module.js:489
    throw err;
          ^
SyntaxError: ...\data\my.json: Unexpected end of input
    at Object.parse (native)
    at Object.Module._extensions..json (module.js:486:27)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at Object.<anonymous> (...\routes\projects.js:72:14)
    at Module._compile (module.js:460:26)
    at Object.Module._extensions..js (module.js:478:10)

我正在使用

fs.unlink

fs.writeFile

我不明白这里发生了什么,完全奇怪......

ps。:我正在使用Express.js

1 个答案:

答案 0 :(得分:1)

问题是在createDataOnceWhenServerFirstTimeStarts中创建文件的代码是异步的。因此,当您尝试加载JSON时,它可能尚未编写。 如果文件已存在,还有另一个问题:fs.unlink也是异步的,在编写文件之前,您不必等待此步骤完成。

如果需要在服务器开始监听之前完成此初始化,我建议您仅使用同步fs方法:

exports.createDataOnceWhenServerFirstTimeStarts = function () {

var myData = ...;//get data from funciton call
var outputFilename = "data/my.json";

if (fs.existsSync(outputFilename)) {
    try {
        fs.unlinkSync(outputFilename);
        console.log("File deleted successfully!");
    } catch (err) {
        return console.error(err);
    }
} else {
    console.log("File does not exist!");
}

var dataToWrite = JSON.stringify(myData);//,null,4);
try {
    fs.writeFileSync(outputFilename, dataToWrite);
    console.log("JSON saved to " + outputFilename);
} catch (err) {
    return console.log(err);
}
};

顺便说一下,您不一定需要先删除(取消链接)该文件,fs.writeFile会覆盖该文件。