Java使用HtmlUnit抓取js渲染页面
Posted 疯子加天才
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java使用HtmlUnit抓取js渲染页面相关的知识,希望对你有一定的参考价值。
需求:
需要采集js渲染的页面,有些网站的页面是js渲染的
实现:
基于htmlUnit实现:
- public static void getAjaxPage() throws Exception{
- WebClient webClient = new WebClient();
- webClient.setjavascriptEnabled(true);
- webClient.setCssEnabled(false);
- webClient.setAjaxController(new NicelyResynchronizingAjaxController());
- webClient.setTimeout(Integer.MAX_VALUE);
- webClient.setThrowExceptionOnScriptError(false);
- HtmlPage rootPage = webClient.getPage("http://tt.mop.com/read_14304066_1_0.html");
- System.out.println(rootPage.asXml());
- }
maven依赖:
- <dependency>
- <groupId>net.sourceforge.htmlunit</groupId>
- <artifactId>htmlunit-core-js</artifactId>
- <version>2.9</version>
- <scope>compile</scope>
- </dependency>
- <dependency>
- <groupId>net.sourceforge.htmlunit</groupId>
- <artifactId>htmlunit</artifactId>
- <version>2.9</version>
- <scope>compile</scope>
- </dependency>
说明:
Nutch插件:nutch-htmlunit用于替换Nutch自身的Http Fetch组件
以上是关于Java使用HtmlUnit抓取js渲染页面的主要内容,如果未能解决你的问题,请参考以下文章