Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Практические руководства
    • Все руководства
    • Разграничение прав доступа для групп пользователей
    • Создание L7-балансировщика с профилем безопасности Smart Web Security через Ingress-контроллер Application Load Balancer
    • Централизованная публикация в интернете и защита приложений от DDoS
    • Передача логов с виртуальной машины в Cloud Logging
    • Запись логов балансировщика в PostgreSQL
    • Безопасное хранение паролей для GitLab CI в виде секретов Yandex Lockbox
    • Сервисный аккаунт с профилем OS Login для управления ВМ с помощью Ansible
    • Передача логов с Container Optimized Image в Cloud Logging
    • Добавление HTML-страницы для работы SmartCaptcha
    • Создание L7-балансировщика с профилем безопасности
    • Настройка алертов в Monitoring
    • Загрузка аудитных логов в MaxPatrol SIEM
    • Загрузка аудитных логов в SIEM Splunk
    • Загрузка аудитных логов в SIEM ArcSight
      • Капча в приложении Android
      • Невидимая капча в приложении Android
      • Капча в приложении Android на Flutter
      • Капча в приложении iOS
    • Шифрование для бакета Object Storage на стороне сервера
    • Шифрование секретов в HashiCorp Terraform
    • Управление ключами KMS с HashiCorp Terraform
    • Auto Unseal в HashiCorp Vault

В этой статье:

  • Перед началом работы
  • Создайте JavaScript Interface
  • Настройте WebView для работы с капчей
  • Получите результат прохождения капчи
  1. Безопасность
  2. Сценарии использования SmartCaptcha
  3. Капча в приложении Android

Yandex SmartCaptcha в приложении на Android

Статья создана
Yandex Cloud
Обновлена 27 декабря 2024 г.
  • Перед началом работы
  • Создайте JavaScript Interface
  • Настройте WebView для работы с капчей
  • Получите результат прохождения капчи

Чтобы встроить SmartCaptcha в приложение на Android:

  1. Создайте JavaScript Interface.
  2. Настройте WebView для работы с капчей.
  3. Получите результат прохождения капчи.

Перед началом работыПеред началом работы

  1. Разместите HTML-страницу на своем сервере или воспользуйтесь страницей на сервере Yandex Cloud — https://smartcaptcha.yandexcloud.net/webview).
  2. Создайте капчу.
  3. На вкладке Обзор получите ключи капчи:
    • Ключ клиента — для загрузки страницы с капчей;
    • Ключ сервера — для получения результата прохождения капчи.

Создайте JavaScript InterfaceСоздайте JavaScript Interface

  1. Создайте класс, который будет принимать сообщения с помощью функции обратного вызова от веб-страницы с капчей.

  2. Определите метод onGetToken(token: String) с аннотацией @JavascriptInterface. Он вызывается, когда веб-страница возвращает токен прохождения капчи:

    class WebJsInterface {
    
      @JavascriptInterface
      fun onGetToken(token: String) {
        //Ваш код.
      }
    }
    

Настройте WebView для работы с капчейНастройте WebView для работы с капчей

  1. Создайте WebView и добавьте его на экран.

  2. Загрузите в WebView URL веб-страницы с капчей.

  3. Вставьте в URL query-параметр sitekey=<ключ_клиентской_части>:

    val webView = findViewById<WebView>(R.id.webViewCaptcha)
    webView.loadUrl("URL_страницы_с_капчей?sitekey=<ключ_клиентской_части>")
    
  4. Добавьте в WebView созданный JavaScript Interface. Укажите вторым параметром NativeClient — это имя, на которое веб-страница будет отправлять сообщения с помощью функции обратного вызова:

    settings.javaScriptEnabled = true // Включает выполнение JavaScript.
    addJavascriptInterface(WebJsInterface(), "NativeClient")
    

Получите результат прохождения капчиПолучите результат прохождения капчи

  1. Сохраните токен прохождения капчи. Он вернется в методе onGetToken(token: String), когда сервис обработает попытку.

  2. Для проверки токена отправьте POST-запрос на адрес https://smartcaptcha.yandexcloud.net/validate, передав параметры в формате x-www-form-urlencoded:

    • secret — ключ сервера;
    • token — одноразовый токен, полученный после прохождения проверки;
    • ip — IP-адрес пользователя, с которого пришел запрос на проверку токена. Этот параметр не обязателен, однако мы просим передавать IP-адрес пользователя при запросах. Это помогает улучшить качество работы SmartCaptcha.

    Примечание

    Данная логика должна выполняться на бэкенде. В само Android-приложение секретный ключ secret попасть не должен.

    Пример запроса:

    https://smartcaptcha.yandexcloud.net/validate?secret=<ключ_сервера>&ip=<IP-адрес_пользователя>&token=<токен>
    
  3. Получите ответ с сервера. Он содержит JSON-объект с полями status и message.

    Например:

    • Это человек:
    {
      "status": "ok",
      "message": ""
    }
    
    • Это робот:
    {
      "status": "failed",
      "message": ""
    }

Была ли статья полезна?

Предыдущая
Сопоставление групп пользователей в Keycloak
Следующая
Невидимая капча в приложении Android
Проект Яндекса
© 2025 ООО «Яндекс.Облако»