2016-11-07 308 views
1

我想使用C#来刮擦网站。在这个过程的某个时候,网站返回一个我需要执行的JavaScript页面,以便它会生成一些参数,然后使用生成的参数作为查询变量发布请求。使用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. web浏览器类
+0

我宁愿使用实际的网络浏览器,即Chrome或Firefox来这样做。为了报废,我会使用Selenium Web Driver。 –

+1

如何使用像硒webdriver + phantomjs的东西? – Hackerman

+0

@AdnanUmer你可以在Selenium Web Driver或任何可以更清楚地理解它的参考资料中提供更多详细信息吗? –

回答

0

你可能刮网站使用名为BIG IP一个防刮擦技术的开发F5.com。

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

相关问题