node.js回调http服务器读取目录

时间:2015-07-24 02:13:54

标签: javascript node.js http fs

新手有一些问题,无法制作脚本显示文件列表,我认为是关于walk是异步的,但我对错误没有任何帮助。

的问候, 马塞洛

// ---- listFiles.js -----------------------------------------------------------
exports.walk = function(currentDirPath, extension,  callback) {

    var fs = require('fs');
    var regex = new RegExp( extension + '$', 'g' );
    fs.readdir( currentDirPath, function (err, files) {
        if (err) callback(err);
        files.filter(function(fname){
            if(fname.match(regex)) {
                callback(null, fname);
            }
        })
    });
    console.log("Fired callback.");
}
// walk('.', 'js', function(err, file){ console.log(file); }); runs OK

// ---- listfilesTest.js --------------------------------------------------------
var http = require('http');
var content = require('./listFiles');
var args = process.argv.slice(2);
console.log(args); // command line arguments (dir & extension)

http.createServer(function (req, res) {
    var files = [];
    res.writeHead(200, {'Content-Type': 'text/plain'});
    res.write('-- list of files --\n');
    content.walk(args[0], args[1], function(err, data){
        if(err) console.error(err);
        //console.log(data);
        res.write(data); // not printing the dir Listings
    } );
    res.end();
}).listen(9000);
// nodemon listFilesTest.js '.' 'js'

1 个答案:

答案 0 :(得分:0)

在执行任何res.end()语句之前,您正在调用res.write()。对content.walk()的回调是异步的,这意味着它将来会发生一些不确定的时间。

您需要在完成所有res.end()语句后调用res.write()exports.walk()的结构方式,调用者无法知道何时完成列出文件并调用回调,因此必须对其进行重组以指示何时完成。

有许多可能的方法来构建它。一个相当简单的方法是在回调中添加一个参数,该信号在列表完成时发出信号。

// ---- listFiles.js -----------------------------------------------------------
exports.walk = function(currentDirPath, extension,  callback) {

    var fs = require('fs');
    var regex = new RegExp( extension + '$', 'g' );
    fs.readdir( currentDirPath, function (err, files) {
        if (err) callback(err);
        files.filter(function(fname){
            if(fname.match(regex)) {
                // call the callback with this filename, not done yet
                callback(null, false, fname);
            }
        })
        // signal that we are done listing the files
        callback(null, true);
        console.log("Done listing files.");
    });
}
// walk('.', 'js', function(err, done, file){ console.log(file); }); runs OK

// ---- listfilesTest.js --------------------------------------------------------
var http = require('http');
var content = require('./listFiles');
var args = process.argv.slice(2);
console.log(args); // command line arguments (dir & extension)

http.createServer(function (req, res) {
    var files = [];
    res.writeHead(200, {'Content-Type': 'text/plain'});
    res.write('-- list of files --\n');
    content.walk(args[0], args[1], function(err, done, data){
        if(err) {
            console.error(err);
            return;
        }
        if (done) {
            res.end();
        } else {
            //console.log(data);
            res.write(data); // not printing the dir Listings
        }
    });
}).listen(9000);