0

JSON ファイルを読み取ってから解析しようとするかなり単純なスクリプトがあります。JSON は非常に単純で、有効であると確信しています。

{
    "foo": "bar"
}

今、私はそれを読んでみましたfs.readFile。読み取り時にエラーは発生せず、返されるデータは文字列です。唯一の問題は、文字列が空であることです。

コードを繰り返しましたが、使用fs.readFileSyncしました。これにより、同じパスを使用してファイルが完全に返されました。両方ともutf-8エンコーディングが指定されていました。

ご覧のとおり、非常に単純なコードです。

fs.readFile('./some/path/file.json', 'utf8', function(err, data) {
    if(!err) {
        console.log(data); // Empty string...
    }
});

console.log(fs.readFileSync('./some/path/file.json', 'utf8')); // Displays JSON file

それは許可または所有権でしょうか?の許可セットを試してみましたが755777役に立ちませんでした。

ノード v0.4.10 を実行しています。私を正しい方向に向けるための提案は大歓迎です。ありがとう。

編集:これが私の実際のコードのブロックです。うまくいけば、これはあなたにより良いアイデアを与えるでしょう.

// Make sure the file is okay
fs.stat(file, function(err, stats) {
    if(!err && stats.isFile()) {
        // It is okay. Now load the file
        fs.readFile(file, 'utf-8', function(readErr, data) {
            if(!readErr && data) {
                // File loaded!
                // Now attempt to parse the config
                try {
                    parsedConfig = JSON.parse(data);
                    self.mergeConfig(parsedConfig);

                    // The config was loaded and merged
                    // We can now call the callback
                    // Pass the error as null
                    callback.call(self, null);

                    // Share the news about the new config
                    self.emit('configLoaded', file, parsedConfig, data);
                }
                catch(e) {
                    callback.call(self, new Error(file + ': The config file is not valid JSON.'));
                }
            }
            else {
                callback.call(self, new Error(file + ': The config file could not be read.'));
            }
        });
    }
    else {
        callback.call(self, new Error(file + ': The config file does not exist.'));
    }
});
4

1 に答える 1

1

これはかなり奇妙です。

コードが見えます。

var fs = require('fs');

fs.readFile('./jsonfile', 'utf8', function(err, data) {
        if(err) {
                console.error(err);
        } else {
                console.log(data);
                parsedConfig = JSON.parse(data);
                console.log(parsedConfig);
                console.log(parsedConfig.foo);
        }
});

Json ファイル:

{
        "foo": "bar"
}

出力:

$ node test_node3.js 
{
        "foo": "bar"
}

{ foo: 'bar' }
bar

これはノード 0.4.10 にありますが、すべてのノード バージョンで動作するはずです。

では、なぜデータが空なのですか? この場合(私のように)エラーをチェックし、出力があれば投稿する必要があります。エラーがなければ、githubでバグを埋めることができます

于 2011-11-12T18:39:19.557 に答える