GithubHelp home page GithubHelp logo

dzmitry-duboyski / solving-yandex-smart-captcha-using-puppeteer Goto Github PK

View Code? Open in Web Editor NEW
10.0 2.0 1.0 20 KB

Решение капчи Yandex SmartCaptcha от Яндекса с использованием библиотеки Puppeteer и сервиса 2captcha

License: MIT License

JavaScript 100.00%
yandex-captcha yandex-smart-captcha captcha-solving puppeteer nodejs puppeteer-demo javascript 2captcha 2captcha-api

solving-yandex-smart-captcha-using-puppeteer's Introduction

Автоматизации решения капчи Yandex SmartCaptcha от Яндекса с использованием библиотеки Puppeteer

Описание

В этом примере показывается как автоматизировать решение капчи Yandex SmartCaptcha на демо странице капчи https://captcha-api.yandex.ru/demo. Для автоматизации используется библиотека Puppeteer и сервис решения капч 2captcha.com. Для корректной работы примера нужен APIKEY, для этого необходимо иметь аккаунт в сервисе 2captcha.com, APIKEY отображается в личном кабинете.

Установка

Клонирование репозитория

git clone https://github.com/dzmitry-duboyski/solving-yandex-smart-captcha-using-puppeteer.git

Установка зависимостей

npm install

Настройка

Установить ваш APIKEY в файле ./index.js#L3

APIKEY указан в личном кабинете аккаунта 2captcha.com. Перед копированием APIKEY, проверьте что в вашем аккаунте выбрана роль "разработчик".

Запуск

npm run start

Код примера

import puppeteer from "puppeteer";
import { Solver } from "2captcha-ts";
const solver = new Solver("<Your 2captcha APIKEY>");

;(async () => {
  const browser = await puppeteer.launch({
    headless: false,
  });

  const page = await browser.newPage();

  // Открыть необходимую страницу с капчей
  // Open target page
  await page.goto("https://captcha-api.yandex.ru/demo");
  await page.waitForSelector("#captcha-container");
  await page.waitForSelector("iframe[data-testid='checkbox-iframe'");

  // Заполнить поля для ввода
  // Enter data
  await page.$eval("#name", (el) => (el.value = ""));
  await page.type("#name", "Иван Иванов", { delay: 100 });

  // Получить параметр `sitekey` с текущей страницы
  // Get the `sitekey` parameter from the current page
  const sitekey = await page.evaluate(() => {
    return document
      .querySelector("#captcha-container")
      .getAttribute("data-sitekey");
  });

  // Отправить капчу в сервис 2captcha.com для получения решения
  // Send a captcha to the 2captcha service to get a solution
  const res = await solver.yandexSmart({
    pageurl: "https://captcha-api.yandex.ru/demo",
    sitekey: sitekey,
  });

  console.log(res);

  // Полученное решение
  // The resulting solution
  const captchaAnswer = res.data;

  // Использовать полученное решение на странице
  // Use the resulting solution on the page
  const setAnswer = await page.evaluate((captchaAnswer) => {
    document.querySelector("input[data-testid='smart-token']").value =
      captchaAnswer;
  }, captchaAnswer);

  // Нажать на кнопку 'Submit', для проверки решения капчи
  // Click on the 'Submit' button to check the captcha solution
  await page.click("#smartcaptcha-demo-submit");

  await page.waitForSelector(".greeting");
  console.log("Капча успешно решена!!!");
  console.log("Captcha solved successfully!!!");

  browser.close();
})();

Исходный код примера доступен в файле index.js

Important

Если вам необходимо решать капчу яндекса которую необходимо кликать, то вам необходимо использовать метод Coordinates API v1 \ Coordinates API v2, подробнее описано в статье.

Дополнительные ссылки:

solving-yandex-smart-captcha-using-puppeteer's People

Contributors

dzmitry-duboyski avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Forkers

galek

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.