selenium 对特定元素截图

本文介绍了如何使用Java和selenium库来处理文字验证码的截图问题。首先,通过全屏截图,然后定位到包含验证码图片和文字提示的div元素,利用TakesScreenshot接口获取截图并裁剪特定元素部分,最终保存图片。这种方法适用于没有直接的元素截图方法的情况。
摘要由CSDN通过智能技术生成

  这段时间在处理文字验证码问题,需要对文字验证码的图片以及提示的图片合成一块来进行截图,然后识别,分析到这两个都有同一个父类html元素,所以拟定对父类元素进行定位,然后截图。
  项目使用Java开发,实现采用senenim对元素截图。因为没有发现更好的对元素截图的方法,所以采用先对整个屏幕进行截图,然后在对具体元素截取这部分图片。
  先对driver进行类型转换成TakesScreenshot,然后调用他的getScreenshotAs(OutputType.FILE);,这里把截图存储文件类型。
OutputType可以指定为文件类型,字节数组,或者是base64编码后的字符串。

File src = ((TakesScreenshot) driver).getScreenshotAs(OutputType.FILE);  

  然后我们分析到具体的元素源码,发现这个class属性值为msn的div标签是验证码图片和文字提示的直接父标签,所以我们这里对定位到这个标签。
avatar

avatar

首先通过driver获取到这个元素

WebElement element = driver.findElement(By.xpath("//div\[@class='msn'\]"));  

  然后调用这个元素的getRect()方法可以获取到这个元素的区域块信息,包括宽度和高度,以及该元素相对于网页最左上原点的坐标。我们这里获取到这些信息,然后对全屏图片进行截图。

Rectangle rect = element.getRect();  
BufferedImage subImage= ImageIO.read(src).getSubimage(rect.x, rect.y, rect.getWidth(), rect.height);  

  这样我们可以对截取后的图片保存到文件,或者其他操作。

ImageIO.write(subImage, "png", src);  

  到此已经完成了对该图片的截取了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值