12

我正在尝试找到一种方法来访问我正在向其发出 HTTP 请求的服务器返回的标签之间的数据。该文档有多个标签,但只有一个标签之间有 JavaScript 代码,其余的都包含在文件中。我想访问脚本标签之间的代码。

代码示例如下:

<html>
    // Some HTML

    <script>
        var spect = [['temper', 'init', []],
                    ['fw\/lib', 'init', [{staticRoot: '//site.com/js/'}]],
                    ["cap","dm",[{"tackmod":"profile","xMod":"timed"}]]];

    </script>

    // More HTML
</html>

我正在寻找一种理想的方法来获取“spect”之间的数据并对其进行解析。有时“spect”和“=”之间有一个空格,有时没有。不知道为什么,但我无法控制服务器。

我知道可能有人问过这个问题,但是回复建议使用 HTMLAgilityPack 之类的东西,我宁愿避免使用库来完成这项任务,因为我只需要从 DOM 中获取 JavaScript 一次。

4

1 回答 1

25

一个非常简单的示例,说明如何使用HTMLAgilityPack侏罗纪库轻松评估结果:

var html = @"<html>
             // Some HTML
             <script>
               var spect = [['temper', 'init', []],
               ['fw\/lib', 'init', [{staticRoot: '//site.com/js/'}]],
               [""cap"",""dm"",[{""tackmod"":""profile"",""xMod"":""timed""}]]];
             </script>
             // More HTML
             </html>";

// Grab the content of the first script element
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(html);
var script = doc.DocumentNode.Descendants()
                             .Where(n => n.Name == "script")
                             .First().InnerText;

// Return the data of spect and stringify it into a proper JSON object
var engine = new Jurassic.ScriptEngine();
var result = engine.Evaluate("(function() { " + script + " return spect; })()");
var json = JSONObject.Stringify(engine, result);

Console.WriteLine(json);
Console.ReadKey();

输出:

[["temper","init",[]],["fw/lib","init",[{"staticRoot":"//site.com/js/"}]],["cap", "dm",[{"tackmod":"profile","xMod":"timed"}]]]

注意:我没有考虑错误或其他任何内容,这仅作为如何获取脚本并评估 spect 值的示例。

还有一些其他的库用于执行/评估 JavaScript。

于 2013-08-09T23:59:09.333 回答