使用 Selenium 和 OpenCV 识别验证码(使用 Java)

验证码的自动识别对于爬虫来说是一个常见的挑战。在这篇文章中,我们将展示如何使用 Selenium 和 OpenCV,结合 Java,来自动化识别网站上的验证码。

配置 Maven 依赖

首先,我们需要在 Maven 项目中添加 Selenium 和 OpenCV 的依赖。

xml

Copy code

<dependencies>

<!-- Selenium -->

<dependency>

<groupId>org.seleniumhq.selenium</groupId>

<artifactId>selenium-java</artifactId>

<version>3.141.59</version>

</dependency>

<!-- OpenCV -->

<dependency>

<groupId>org.openpnp</groupId>

<artifactId>opencv</artifactId>

<version>4.5.1-1</version>

</dependency>

</dependencies>

获取验证码图片

使用 Selenium 打开目标网站,找到验证码图片的元素,并将其截图保存到本地。

import org.openqa.selenium.By;

import org.openqa.selenium.WebDriver;

import org.openqa.selenium.WebElement;

import org.openqa.selenium.chrome.ChromeDriver;

public class CaptchaSolver {

public static void main(String\[\] args) {

WebDriver driver = new ChromeDriver();

driver.get("https://example.com");

WebElement captchaElement = driver.findElement(By.id("captcha"));

captchaElement.getScreenshotAs(OutputType.FILE);

// 在此处保存截图到本地

// 例如:FileUtils.copyFile(captchaFile, new File("captcha.png"));

driver.quit();

}

}

识别验证码

使用 OpenCV 读取保存的验证码图片,并使用图像处理技术识别其中的文本。

import org.opencv.core.Core;

import org.opencv.core.Mat;

import org.opencv.core.MatOfByte;

import org.opencv.highgui.HighGui;

import org.opencv.imgcodecs.Imgcodecs;

import org.opencv.imgproc.Imgproc;

public class CaptchaSolver {

public static void main(String\[\] args) {

System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Mat image = Imgcodecs.imread("captcha.png", Imgcodecs.IMREAD_GRAYSCALE);

// 在此处加入验证码识别的代码,例如使用 OCR 技术

}

}

自动填充验证码

最后,我们可以将识别出的验证码文本自动填充到网站上的相应输入框中,完成验证码的自动识别。

import org.openqa.selenium.By;

import org.openqa.selenium.WebDriver;

import org.openqa.selenium.WebElement;

import org.openqa.selenium.chrome.ChromeDriver;

public class CaptchaSolver {

public static void main(String\[\] args) {

WebDriver driver = new ChromeDriver();

driver.get("https://example.com");

WebElement captchaInput = driver.findElement(By.id("captchaInput"));

// 在此处填充识别出的验证码文本

// 例如:captchaInput.sendKeys("识别出的验证码文本");

// 在此处继续你的自动化操作,例如提交表单或点击按钮

driver.quit();

}

}

如果上述代码遇到问题或已更新无法使用等情况可以联系Q:1436423940或直接访问www.ttocr.com测试对接(免费得哈)

相关推荐
IT_陈寒1 小时前
Vue这个坑我跳了两次,原来问题出在这
前端·人工智能·后端
新新技术迷1 小时前
Node给AI接口做SSE代理与鉴权
人工智能
redreamSo2 小时前
大模型是不是到顶了?瓶颈到底在哪
人工智能·openai
Oo9202 小时前
Tool Use 背后的技术逻辑
人工智能
姗姗来迟了2 小时前
Vue3封装AI流式对话组件踩坑实录
人工智能
码上天下3 小时前
用Pinia管理AI多会话状态
人工智能
用户054324329704 小时前
Next.js接大模型流式SSE实操踩坑
人工智能
Assby4 小时前
从 Function Calling 到 MCP:理解 Agent 工具调用的底层通信机制
人工智能·后端
小星AI4 小时前
Claude Code 从入门到精通,一步到位
人工智能
后端小肥肠4 小时前
Codex + Obsidian 做人生副本视频:输入主题文案,直通剪映草稿
人工智能·aigc·agent