Реализация App Links для Android-приложения

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация App Links для Android-приложения
Средняя
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    760
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    646
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1062
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    878
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    450

Реализация App Links для Android-приложения

App Links — это верифицированные deep links, которые Android открывает напрямую в приложении без диалога выбора браузера. Разница принципиальная: обычный intent-filter с http-схемой показывает пользователю «открыть в браузере или в приложении». App Links с верификацией через .well-known/assetlinks.json — открывают приложение сразу. Для маркетинговых ссылок, email-кампаний и QR-кодов это прямо влияет на конверсию.

Технический механизм

В манифесте intent-filter прописывается с android:autoVerify="true" и схемой https. Android при установке приложения (и при обновлении, с API 31 — асинхронно в фоне) обращается к https://your-domain.com/.well-known/assetlinks.json и проверяет, что SHA-256 fingerprint подписи приложения совпадает с записью в файле.

<intent-filter android:autoVerify="true">
    <action android:name="android.intent.action.VIEW" />
    <category android:name="android.intent.category.DEFAULT" />
    <category android:name="android.intent.category.BROWSABLE" />
    <data android:scheme="https" android:host="example.com" />
</intent-filter>

Файл assetlinks.json размещается на сервере с Content-Type application/json и без редиректов — верификатор не следует по редиректам. Типичная ошибка: файл отдаётся с редиректом http → https или с неправильным MIME-типом text/plain. Верификация падает молча — в логах adb shell pm get-app-links --user 0 com.example.app видно статус 1024 (failed).

Fingerprint подписи — не тот, что в debug.keystore. Production App Links работают только с release-подписью. При использовании Google Play App Signing нужен fingerprint из Google Play Console → Setup → App signing, а не локального keystore.

Где чаще всего ломается верификация

Несколько доменов. Приложение хочет открываться и по example.com, и по www.example.com, и по m.example.com. Каждый домен требует своего intent-filter и своего assetlinks.json на каждом поддомене. Забыли про www — ссылки с www открываются в браузере.

Субдомены и wildcards. android:host не поддерживает wildcards типа *.example.com. Каждый субдомен — отдельная запись. Для приложений с динамическими субдоменами (мультитенантные SaaS) App Links не подходят — нужен кастомный URI-scheme.

API 31+ и Package Visibility. С Android 12 изменилось поведение верификации: если домен верифицировался раньше, переверификация при обновлении происходит асинхронно. В период до завершения верификации ссылки могут открываться с диалогом выбора. Решение — adb shell pm verify-app-links --re-verify com.example.app для форсированной верификации в тестировании.

Обработка в Activity. Intent с ACTION_VIEW приходит в onCreate (при холодном старте) и в onNewIntent (если Activity уже запущена с launchMode="singleTop" или singleTask). Пропустить onNewIntent — значит потерять deep link при переходе из фона.

Что настраиваем помимо базовой верификации

Параметры в URI-пути нужно корректно парсить — через Uri.getQueryParameter(), а не ручным разбором строки. Если приложение использует Navigation Component, NavDeepLinkBuilder и deepLink {} в NavGraph обрабатывают маппинг URI → экран декларативно.

Для аналитики каждый обработанный deep link должен логироваться с источником — это позволяет отслеживать конверсию маркетинговых кампаний через Firebase Analytics или Amplitude.

Сроки: настройка App Links с верификацией — 1-2 дня. Если нужна обработка нескольких доменов, параметров и интеграция с навигацией — 2-3 дня. Стоимость рассчитывается индивидуально.