Реализация авторизации через OAuth 2.0 в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.

Разработка и поддержка любых видов мобильных приложений:

Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

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

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Реализация авторизации через OAuth 2.0 в мобильном приложении
Средний
от 1 дня до 3 дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    792
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    671
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1097
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    969
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    914
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    495

Реализация авторизации через OAuth 2.0 в мобильном приложении

OAuth 2.0 в мобильном контексте — это не то же самое, что OAuth 2.0 в вебе. Authorization Code Flow с PKCE (Proof Key for Code Exchange) — единственный правильный вариант для нативных приложений. Implicit Flow официально deprecated в RFC 9700. Client Credentials не подходит — нет пользовательского контекста. Если кто-то предлагает Implicit Flow для мобилки в 2024 — это красный флаг.

Почему PKCE обязателен

Нативное приложение не может безопасно хранить client_secret. Файл APK / IPA декомпилируется за минуты — любой секрет, зашитый в бинарник, считается скомпрометированным по определению. PKCE решает эту проблему без client_secret: генерируем code_verifier (случайная строка 43–128 символов), хешируем SHA-256 → code_challenge, передаём challenge при запросе авторизации. При обмене кода на токен передаём оригинальный verifier — сервер проверяет совпадение. Перехватить code и использовать без verifier невозможно.

code_verifier генерируем криптографически:

// iOS
var buffer = [UInt8](repeating: 0, count: 32)
_ = SecRandomCopyBytes(kSecRandomDefault, buffer.count, &buffer)
let verifier = Data(buffer).base64URLEncodedString()
// Android
val bytes = ByteArray(32)
SecureRandom().nextBytes(bytes)
val verifier = Base64.encodeToString(bytes, Base64.URL_SAFE or Base64.NO_PADDING or Base64.NO_WRAP)

Redirect URI и Custom URL Schemes

Второй болезненный момент — перехват redirect. Custom URL Scheme (myapp://callback) может быть перехвачен другим приложением на устройстве, зарегистрировавшим тот же scheme. Правильный вариант — HTTPS App Links (Android) и Universal Links (iOS). Сервер авторизации редиректит на https://yourapp.com/callback, система проверяет assetlinks.json / apple-app-site-association и передаёт URL непосредственно вашему приложению.

Настройка Universal Links требует:

  • AASA-файл на домене по адресу https://yourapp.com/.well-known/apple-app-site-association
  • Associated Domains capability в Xcode с записью applinks:yourapp.com
  • Обработка URL в scene(_:continue:) или application(_:continue:restorationHandler:)

На Android — Digital Asset Links файл и intent-filter с autoVerify="true".

Библиотеки

Не пишем OAuth 2.0 + PKCE с нуля. Используем:

  • iOS: AppAuth-iOS (openid.net, актуальная версия 1.7+)
  • Android: AppAuth-Android
  • React Native: react-native-app-auth
  • Flutter: flutter_appauth

AppAuth берёт на себя генерацию PKCE, открытие браузера (через ASWebAuthenticationSession на iOS, Custom Tabs на Android), обработку redirect и обмен кода на токен.

Хранение токенов

Access token — в памяти (@State, ViewModel). Не в UserDefaults, не в SharedPreferences. Refresh token — в Keychain (iOS) или EncryptedSharedPreferences / Android Keystore (Android). Access token живёт 15–60 минут, refresh — дни или недели. Разный уровень чувствительности — разный уровень хранения.

Перехват refresh token из SharedPreferences на рутованном Android-устройстве — реальный вектор атаки. EncryptedSharedPreferences из androidx.security:security-crypto закрывает этот сценарий на устройствах с Android Keystore (API 23+).

Работа с несколькими identity providers

Типичный кейс: вход через Google, Apple, корпоративный SAML IdP. Архитектурно — единый OAuthService с протоколом/интерфейсом, разные провайдеры как конкретные реализации. Токены разных провайдеров не смешиваем — каждый хранится под своим ключом в Keychain/Keystore.

"Sign in with Apple" обязателен для App Store, если есть вход через Google или Facebook — гайдлайн 4.8. Нарушение → отклонение на ревью.

Процесс и сроки

Аудит существующего auth (если есть) → выбор/настройка Authorization Server → реализация PKCE flow через AppAuth → настройка Universal/App Links → хранение токенов → refresh flow → тестирование на реальных устройствах → интеграционные тесты с Authorization Server.

Срок: 5–10 рабочих дней для одного провайдера. Каждый дополнительный провайдер — плюс 2–3 дня. Настройка корпоративного SAML/OIDC на стороне сервера не входит в эту оценку.