使用c#执行JavaScript页面

本文关键字:页面 JavaScript 执行 使用 | 更新日期: 2023-09-27 18:16:36

我正在尝试使用c#抓取一个网站。在这个过程中的某个时刻,网站返回一个我需要执行的JavaScript页面,这样它就会生成一些参数,然后使用生成的参数作为查询变量发布请求。

这是JavaScript文件https://jsfiddle.net/7aw5vr59/

浏览器生成的结果文件如下所示:

<imimxxxyyy id="ActiveX"></imimxxxyyy><form action="/home/" method="post"><input name="TS013a5875_id" value="3" type="hidden"><input name="TS013a5875_cr" value="085d52524cab2800109920a8877032c63ff20a076afde32d3949a9c0cc832e2a409e921dbd0f04b390bc9a36f79f4d080873a7f6848948001fe9d70f9af2fa1f81ba0cb687810509e2df6f37950961d59dba504d18b2e08237af58ac5683f65a8b9a4c978624319575ee9b400ae2307cbb314a0f32ecca4464cdc6b2082f7352" type="hidden"><input name="TS013a5875_76" value="085d52524cab2800109920a8877032c63ff20a076afde32d3949a9c0cc832e2a409e921dbd0f04b390bc9a36f79f4d080873a7f68488b000c2ff7c505061da44dff5459af7ebe2f604b8d36bdeeeca3eead0e146af07190233b9414ca790443d2453827dc161e073eb63ed4d10c070e405848b2ccb2dc1c4412b93dff97f978c6f1caecff07f6d4c23e1ade1bfb2f715409cf4d5f1f91a826e092193a1407539ec35c80a0d82032163abc93f6876c7c1cecded7400c11873a90a0ad58c3d18b0a55b0a0430c50575d7f535fd9b414c06b1c3b11ab326b07356737269137f2610cf26df27c7e0bcd5" type="hidden"><input name="TS013a5875_86" value="085d52524cab2800109920a8877032c63ff20a076afde32d3949a9c0cc832e2a409e921dbd0f04b390bc9a36f79f4d080873a7f68486600098382373b7447eebb69eb2b508714f7fb748b827881d272fff290b8bcf8bef6184c2a8c9f1236e71539573e709a14a158df0bb128ca0ba6e196a5b4a979b28a93e07d7089584e53a1ae51612c25ee3012964be00bc312836a58d7543f2cd825f" type="hidden"><input name="TS013a5875_md" value="1" type="hidden"><input name="TS013a5875_rf" value="0" type="hidden"><input name="TS013a5875_ct" value="0" type="hidden"><input name="TS013a5875_pd" value="0" type="hidden"></form>
正如您在末尾看到的,表单中有以TS013a5875开头的变量。我应该在我的代码中做同样的事情。谁能告诉我怎么做?

我试了下面的,但没有运气。此外,应用程序是紧密耦合的,可以添加更多的外部依赖项。

  1. 使用侏罗纪引擎
  2. ScrapySharp
  3. <
  4. WebBrowser类/gh>

使用c#执行JavaScript页面

您正在抓取的网站可能使用了由F5.com开发的名为BIG IP的反抓取技术。

你应该使用一个能够执行javascript的浏览器,并且有一些真正的功能,比如渲染画布。你可以尝试像PhantomJS这样的无头浏览器,但它可能无法工作。