java1234开源博客系统
博客信息

htmlunit 模拟指定浏览器

发布时间:『 2017-04-07 10:05』  博客类别:htmlunit  阅读(6957) 评论(0)

前面我们的测试代码是直接请求的,有些网站服务器防火墙会直接拒绝访问。

我们现在用htmlunit来模拟下浏览器请求;主要是加了一些头消息;


QQ鎴浘20170407100204.jpg


这个是我们用火狐调试工具看到的请求头小心里的属性,当然上面还有返回的头消息;

我们用htmlunit可以模拟浏览器执行,内置的可以模拟IE,火狐,谷歌;


WebClient构造方法里有个重载方法,可以加一个指定版本属性;

QQ鎴浘20170407095601.jpg



完整代码:

package com.open1111;

import java.io.IOException;
import java.net.MalformedURLException;

import com.gargoylesoftware.htmlunit.BrowserVersion;
import com.gargoylesoftware.htmlunit.FailingHttpStatusCodeException;
import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.html.HtmlPage;

public class HtmlUnitTest {

	public static void main(String[] args) {
		WebClient webClient=new WebClient(BrowserVersion.FIREFOX_52); // 实例化Web客户端	
		try {
			HtmlPage page=webClient.getPage("http://www.java1234.com"); // 解析获取页面
			System.out.println("网页html:"+page.asXml()); // 获取Html
			System.out.println("====================");
			System.out.println("网页文本:"+page.asText()); // 获取文本
		} catch (FailingHttpStatusCodeException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (MalformedURLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			webClient.close(); // 关闭客户端,释放内存
		}
	}
}

运行效果和前面的一样;

关键字:   htmlunit     模拟浏览器  
关注Java1234微信公众号
博主信息
Java1234_小锋
(知识改变命运,技术改变世界)
Powered by Java1234 V3.0 Copyright © 2012-2016 Java知识分享网 版权所有