HtmlUnit入门
来源:互联网 发布:windows 2000系统 编辑:程序博客网 时间:2024/06/07 03:46
HtmlUnit介绍
htmlunit 是一款开源的java 页面分析工具,读取页面后,可以有效的使用htmlunit分析页面上的内容。项目可以模拟浏览器运行,被誉为java浏览器的开源实现。是一个没有界面的浏览器,运行速度迅速。
入门案例
pom.xml加入依赖
<dependency> <groupId>net.sourceforge.htmlunit</groupId> <artifactId>htmlunit</artifactId> <version>2.23</version> </dependency>
获取页面内容
/** * 获取页面内容 */ public class HtmlUnitDemo03 { public static void main(String[] args) { //实例化web客户端 WebClient webClient = new WebClient(BrowserVersion.FIREFOX_45,"124.206.107.125",3128);//使用代理IP try { //解析获取页面 HtmlPage page = webClient.getPage("http://www.java1234.com"); HtmlElement div = page.getHtmlElementById("navMenu"); System.out.println(div.asXml()); System.out.println("---------------"); //获取a标签 DomNodeList<DomElement> dnList = page.getElementsByTagName("a"); for (int i = 0; i < dnList.getLength(); i++) { DomElement element = dnList.get(i); System.out.println(element.asXml()); System.out.println(element.asText()); } System.out.println("------------------"); List<HtmlListItem> itemList = (List<HtmlListItem>) page.getByXPath("//div[@id='navMenu']/ul/li"); System.out.println(itemList.get(0).asXml()); } catch (FailingHttpStatusCodeException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (ElementNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { //释放资源 webClient.close(); } } }
取消css,js支持
/** * 取消css,js支持 */ public class HtmlUnitDemo04 { public static void main(String[] args) { //实例化web客户端 WebClient webClient = new WebClient(BrowserVersion.FIREFOX_45,"124.206.107.125",3128);//使用代理IP //取消css支持 webClient.getOptions().setCssEnabled(false); //取消js支持 webClient.getOptions().setJavaScriptEnabled(false); try { //解析获取页面 HtmlPage page = webClient.getPage("http://www.java1234.com"); HtmlElement div = page.getHtmlElementById("navMenu"); System.out.println(div.asXml()); System.out.println("---------------"); //获取a标签 DomNodeList<DomElement> dnList = page.getElementsByTagName("a"); for (int i = 0; i < dnList.getLength(); i++) { DomElement element = dnList.get(i); System.out.println(element.asXml()); } System.out.println("------------------"); List<HtmlListItem> itemList = (List<HtmlListItem>) page.getByXPath("//div[@id='navMenu']/ul/li"); System.out.println(itemList.get(0).asXml()); } catch (FailingHttpStatusCodeException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (ElementNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { //释放资源 webClient.close(); } } }
模拟表单搜索
/** * 模拟表单搜索 */ public class HtmlUnitDemo05 { public static void main(String[] args) { //实例化web客户端 WebClient webClient = new WebClient(BrowserVersion.FIREFOX_45,"124.206.107.125",3128);//使用代理IP try { //解析获取页面 HtmlPage page = webClient.getPage("http://blog.java1234.com/index.html"); //获取搜索表单 HtmlForm form = page.getFormByName("myform"); //获取查询文本框 HtmlTextInput textInput = form.getInputByName("q"); //获取提交按钮 HtmlSubmitInput submitInput = form.getInputByName("submitButton"); //输入文本框 textInput.setValueAttribute("java"); //模拟提交(点击) HtmlPage resultPage = submitInput.click(); System.out.println(resultPage.asXml()); } catch (FailingHttpStatusCodeException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (ElementNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { //释放资源 webClient.close(); } } }
获取ajax加载的内容
/** * 获取ajax加载的内容 */ public class HtmlUnitDemo06 { public static void main(String[] args) { //实例化web客户端 WebClient webClient = new WebClient(BrowserVersion.FIREFOX_45);//使用代理IP try { //解析获取页面 HtmlPage page = webClient.getPage("https://pan.baidu.com/share/home?uk=305605848#category/type=0"); //等待htmlunit执行js Thread.sleep(10000); System.out.println("网页html:"+page.asXml()); } catch (FailingHttpStatusCodeException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (ElementNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } finally { //释放资源 webClient.close(); } } }
阅读全文
0 0
- HtmlUnit入门
- HtmlUnit测试入门
- 简单入门HtmlUnit
- HtmlUnit
- HTMLUnit
- htmlunit
- htmlunit
- HtmlUnit
- htmlunit
- HtmlUnit学习笔记(一)--快速入门
- HtmlUnit基础
- htmlunit 示例
- java htmlunit
- htmlunit学习
- htmlunit示例
- HtmlUnit入门教程
- htmlunit教程
- htmlunit 优化
- 抽象类的实例化问题
- Shell编程相关知识整理
- Java io 流的理解
- 【unity3d学习笔记】Shader-通过Shader实现2D游戏中无限滚动的背景Shader
- loarunner(一)
- HtmlUnit入门
- Java中的自动装箱与拆箱
- tf.nn.seq2seq.sequence_loss_by_example函数用法
- 【SPOJ7001】Visible Lattice Points-莫比乌斯反演+分块
- (150)带光照的半透明物体
- Tarjan算法研究:求強連通分量、橋、割
- 《Android那些事》——清晰理解各个Animation
- C语言堆栈问题
- 网络:TCP通讯之 time_wait 状态