此路由导致我的服务器慢慢耗尽内存,我无法弄清楚原因。由于目标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"
});
}
});
});
...
答案 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"
}
}