xml2js没有解析通过代理检索的xml

时间:2015-02-17 15:35:37

标签: xml node.js proxy

我正在使用nodejs应用程序并使用xml2js来解析xml文件。 当xml文件是本地的时,我用xml2js解析它没有问题,但是,我需要检索远程xml文件,我需要通过代理连接。

此代码(读取本地xml文件)有效:

var rundownParser = new xml2js.Parser();
function parseRundown(){
    fs.readFile(rundownFolder + '/' + rundownFile, function(err, data) {
        rundownParser.parseString(data);
    });
}
rundownParser.on('end', function(result) {
    console.log("PARSER ENDED")
});

这是我通过代理检索远程XML文件的代码:

    var rundownParser = new xml2js.Parser();    
    function parseRundown(){
        var options = {
          host: proxyHost,
          port: proxyPort,
          path: mosGatewayPath,
          method: 'GET',
          headers : {
              host: mosGatewayHost
          }
        };

        var req = http.request(options, function(res) {
            res.on('data', function (response) {
                console.log("REMOTE DATA: "+response)
                rundownParser.parseString(response); 
            });
        });
        req.end();
    }
    rundownParser.on('end', function(result) {
        console.log("PARSER ENDED")
});

在检索远程文件的代码中,我在'data'事件中看到了正确的响应。所以我知道连接正在运行,但之后它只是挂起,它永远不会到达解析器的'end'事件。没有错误。

我非常感谢任何帮助,指出我做错了什么。

TIA!

1 个答案:

答案 0 :(得分:0)

在响应发出后,尝试调用parseString'结束'。

e.g。

var req = http.request(options, function(res) {
    var body;

    res.on('data', function (data) {
        body += data
    });

    res.on('end', function() {
      console.log("REMOTE DATA: "+body)
      rundownParser.parseString(body); 
    });
});