记录Htmlunit使用中遇到的大坑(一)

分享一些htmlunit实际使用过程中遇到的问题。

1、解析js失败

下面这个是我用htmlunit模拟访问我们公司的一个vue项目时,遇到的报错。

@Test
    public void test1() throws IOException, SAXException {
        System.out.println("hello world");
        WebClient webClient = new WebClient(BrowserVersion.CHROME);
        webClient.getOptions().setCssEnabled(false);
        webClient.getOptions().setJavaScriptEnabled(true);
        HtmlPage htmlpage = webClient.getPage("http://177.61.11.999:8080/");        
}

 HtmlPage htmlpage = webClient.getPage("http://177.61.11.999:8080/"); 这行getPage报错。

======= EXCEPTION START ========
EcmaError: lineNumber=[1] column=[0] lineSource=[<no source>] name=[TypeError] sourceName=[http://10.1.3.32:8080/cdn/vxe-table/vxe-table.js] message=[TypeError: Expected argument of type object, but instead had type object (http://10.1.3.32:8080/cdn/vxe-table/vxe-table.js#1)
]
com.gargoylesoftware.htmlunit.ScriptException: TypeError: Expected argument of type object, but instead had type object (http://10.1.3.32:8080/cdn/vxe-table/vxe-table.js#1)
    at com.gargoylesoftware.htmlunit.javascript.JavaScriptEngine$HtmlUnitContextAction.run(JavaScriptEngine.java:705)
    at net.sourceforge.htmlunit.corejs.javascript.Context.call(Context.java:620)
    at net.sourceforge.htmlunit.corejs.javascript.ContextFactory.call(ContextFactory.java:513)
    at com.gargoylesoftware.htmlunit.javascript.JavaScriptEngine.execute(JavaScriptEngine.java:591)

 

EcmaError: lineNumber=[1] column=[0] lineSource=[<no source>]

这一行表示,htmlunit在解析这个js文件时,从第一个字符就开始报错,解析js失败。

我找到这个js的代码发现,这个js并没有什么问题。问题就出在htmlunit对他的解析上。

解决办法:方式1、webclient.getOptions.setJavaScriptEnable(true);  true改成false

禁用js,或者报错就没有了。这个就属于是掩耳盗铃,脚疼跺脚,禁用js那所有动态内容都拿不到了,不报错也没什么意义。

方式2 、更换更高htmlunit版本

我更换了2.15、2.34以及最新的2.7版本。都没有解决这个问题。在使用2.7版本的时候,出现了栈溢出。可以看出来htmlunit是比较努力的解决这个问题的,但是很遗憾他失败了。

如果你遇到同样的问题,js解析失败,更换版本也许有用,理论上越高版本对js的支持也就越好。

方式3、give up

适时选择放弃,死磕没有意义。这个页面你注定扒不了了。换个页面。

我最终选择方式3.

总结:htmlunit对js的支持是有限的,有的就是不支持。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
HTMLUnit是一个Java库,它用于模拟浏览器行为并执行Web页面的自动化测试。下面是一个简单的HTMLUnit使用教程: 1. 首先,你需要在你的Java项目导入HTMLUnit库。你可以通过在你的构建工具(如Maven或Gradle)添加以下依赖来实现: ```xml <dependency> <groupId>net.sourceforge.htmlunit</groupId> <artifactId>htmlunit</artifactId> <version>2.53.0</version> </dependency> ``` 2. 创建一个新的Java类,并导入HTMLUnit相关的类和方法: ```java import com.gargoylesoftware.htmlunit.WebClient; import com.gargoylesoftware.htmlunit.html.HtmlPage; ``` 3. 在你的代码创建一个WebClient对象,并启用JavaScript支持(如果需要执行JavaScript): ```java WebClient webClient = new WebClient(); webClient.getOptions().setJavaScriptEnabled(true); ``` 4. 使用WebClient对象获取HtmlPage对象,该对象表示要测试的Web页面: ```java HtmlPage page = webClient.getPage("http://example.com"); ``` 5. 一旦你有了HtmlPage对象,你就可以通过使用HTML DOM模型的方法来获取页面的元素或执行其他操作。例如,你可以通过元素的ID获取元素: ```java HtmlElement element = page.getElementById("myElementId"); ``` 6. 你还可以模拟用户与页面的交互,例如填写表单、点击按钮等。例如,要填写一个文本框,你可以使用以下代码: ```java HtmlTextInput textField = (HtmlTextInput) page.getElementById("myTextFieldId"); textField.setValueAttribute("Hello, HTMLUnit!"); ``` 7. 最后,记得在使用完毕后关闭WebClient对象,以释放资源: ```java webClient.close(); ``` 这只是一个HTMLUnit的简单使用教程,你可以根据你的具体需求进一步深入学习和了解HTMLUnit的功能和特性。希望对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值