NodeJS内存泄漏

时间:2014-09-22 22:58:39

标签: javascript html node.js express jsdom

此路由导致我的服务器慢慢耗尽内存,我无法弄清楚原因。由于目标URL的古老SSL版本,所以必须使用荒谬的exec()表达式和解析,并且我无法让任何节点SSL库信任或忽略。欢迎任何有关改进此代码的其他建议。

(function() {
  var exec, express, fs, https, jsdom, qs, router, util;

  express = require("express");
  jsdom = require('jsdom');
  exec = require('exec');
  https = require('https');
  qs = require('querystring');
  fs = require('fs');
  util = require('util');

  router = express.Router();

  router.get("/getVars", function(req, res) {
    res.set({
      "Cache-Control": 'max-age=86400'
    });
    return exec("curl -m 6 -1 'https://some.url.com'", function(err, b, stderr) {
      if (b) {
        return jsdom.env(b, ["http://code.jquery.com/jquery.js"], function(err, window) {
          var eventvalidation, viewstate;
          viewstate = window.$("#__VIEWSTATE").val();
          eventvalidation = window.$("#__EVENTVALIDATION").val();
          return res.json({
            viewstate: viewstate,
            eventvalidation: eventvalidation
          });
        });
      } else {
        return res.json({
          viewstate: "verylongstring",
          eventvalidation: "verylongstring"
        });
      }
    });
  });

...

1 个答案:

答案 0 :(得分:1)

我建议消除jsdom,因为它是一个非常重要的组件,满足您的有限需求,这可能会更好地配合几个正则表达式,见下文。

  ...
  return res.json(getDataFromString(b || ''));
  ...

function getDataFromString(input){
  return {
    viewstate: (/id=\"__VIEWSTATE\" value=\"([^\"]*)\"/).exec(input)[1] || "verylongstring",
    eventvalidation: (/id=\"__EVENTVALIDATION\" value=\"([^\"]*)\"/).exec(input)[1] || "verylongstring"
  }
}