与文件系统readFile和xml2js parseString挂起的请求

时间:2013-11-11 21:23:37

标签: javascript node.js express

这是我正在使用的软件包的版本:

node.js  0.10.3
express  3.4.4
jade     0.35.0
xml2js   0.2.8

我遇到了一个奇怪的问题,我的第二个ajax请求(/ tasks之一)处于暂停状态几分钟。

我的javascript调用:

$('#add-task').click(function(){
    $.post('/addTask', function(){
        loadTasks();
    });
});

function loadTasks(){
    $.get('/tasks', function(tasks){
        $('#tasks > tbody').html(tasks);
    });
}

这里我的路线档案:

exports.addTask = function(req, res){
    fs.readFile(xmlPath, function(err, data) {
        parser.parseString(data, function (err, result) {
            var ws = fs.createWriteStream(xmlPath),
                xw = new XMLWriter(true, function(string, encoding) { 
                    ws.write(string, encoding);
                });
            xw.startDocument('1.0', 'UTF-8').startElement(function() {
                return 'tasks';
            });
            for(var i in result.tasks.task) {
                var task = xmlTaskToObject(result.tasks.task[i]);
                writeTaskToXml(xw, task);
            }
            req.body.index = (result.tasks.task !== undefined) ? result.tasks.task.length : 0;
            writeTaskToXml(xw, req.body);
            xw.endElement();
            ws.end();
            res.send('');
        });
    });
};

exports.tasks = function(req, res){
    var tasks = [];

    fs.readFile(xmlPath, function(err, data) {
        if(err){
            throw err;
        }
        parser.parseString(data, function (err, result) {
            console.log("AFTER PARSER");
            // parsing stuff
            /*
            ...
            */
            res.render('tasks', { tasks: tasks });
        });
    });
};

“AFTER PARSER”永远不会在控制台中显示,也不会抛出异常......

我找到解决问题的唯一方法是使用超时执行第二次ajax调用,如下所示:

$.post('/addTask', function(){
    setTimeout(loadTasks, 100);
});

有人可以告诉我出了什么问题?我想这是一个文件访问问题或类似的东西。

谢谢!

1 个答案:

答案 0 :(得分:2)

您没有发送回复。 res.render不会执行res.send。

这应该有效:

        res.render('tasks', { tasks: tasks }, 
                   function(err, html) { res.send(html); } );

修改 问题的另一部分是关闭文件。您需要等待.end()完成(http://nodejs.org/api/stream.html#stream_writable_end_chunk_encoding_callback):

        xw.endElement();
        ws.on('finish', function() {
            res.send('');
        });
        ws.end();