Интеграция push-уведомлений через Firebase Cloud Messaging (FCM)

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

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Интеграция push-уведомлений через Firebase Cloud Messaging (FCM)
Средняя
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1052
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    862
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Интеграция push-уведомлений через Firebase Cloud Messaging (FCM)

FCM — стандарт push-уведомлений для Android. Но «добавить Firebase» и «правильно интегрировать FCM» — разные вещи. Типичные проблемы: уведомления приходят, когда приложение открыто, и пропадают в background. Или приходят, но без кастомного звука и иконки. Или токен обновляется, а сервер об этом не знает.

Типы сообщений FCM: notification vs data

Это различие критично и часто понимается неправильно.

Notification message (display message): FCM SDK показывает уведомление автоматически, когда приложение в background/terminated. Кастомизация ограничена — только title, body, icon, color. onMessageReceived в foreground вызывается, в background — нет.

Data message: payload содержит только data без блока notification. FCM не показывает ничего автоматически. onMessageReceived вызывается всегда — и в foreground, и в background, и в terminated (через FirebaseMessagingService). Полный контроль над отображением.

Для большинства реальных приложений правильный выбор — data-only с ручным построением уведомления в onMessageReceived.

Настройка сервиса

class PushMessagingService : FirebaseMessagingService() {

    override fun onNewToken(token: String) {
        // Отправить token на сервер
        ApiClient.registerFcmToken(token)
    }

    override fun onMessageReceived(message: RemoteMessage) {
        val title = message.data["title"] ?: return
        val body = message.data["body"] ?: return
        showNotification(title, body, message.data)
    }

    private fun showNotification(title: String, body: String, data: Map<String, String>) {
        val channelId = "default_channel"
        val intent = Intent(this, MainActivity::class.java).apply {
            flags = Intent.FLAG_ACTIVITY_SINGLE_TOP
            putExtra("payload", data.toString())
        }
        val pendingIntent = PendingIntent.getActivity(
            this, 0, intent,
            PendingIntent.FLAG_UPDATE_CURRENT or PendingIntent.FLAG_IMMUTABLE
        )

        val notification = NotificationCompat.Builder(this, channelId)
            .setSmallIcon(R.drawable.ic_notification) // Важно: белая иконка на прозрачном фоне
            .setContentTitle(title)
            .setContentText(body)
            .setAutoCancel(true)
            .setContentIntent(pendingIntent)
            .build()

        NotificationManagerCompat.from(this).notify(System.currentTimeMillis().toInt(), notification)
    }
}

ic_notification — белая монохромная иконка 24dp. Если передать цветную — Android 5+ покажет серый квадрат вместо иконки. Это самая частая визуальная ошибка.

Notification Channels (Android 8+)

Без канала уведомление не покажется на Android 8+. Канал создаётся один раз при запуске:

fun createNotificationChannel(context: Context) {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
        val channel = NotificationChannel(
            "default_channel",
            "Основные уведомления",
            NotificationManager.IMPORTANCE_HIGH
        ).apply {
            description = "Сообщения и обновления"
            enableLights(true)
            lightColor = Color.BLUE
            enableVibration(true)
        }
        context.getSystemService(NotificationManager::class.java)
            ?.createNotificationChannel(channel)
    }
}

IMPORTANCE_HIGH — уведомление с звуком и heads-up. IMPORTANCE_DEFAULT — без heads-up. Выбор зависит от типа уведомлений.

Разрешение POST_NOTIFICATIONS (Android 13+)

// Android 13+ требует явного разрешения
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
    ActivityCompat.requestPermissions(
        activity,
        arrayOf(Manifest.permission.POST_NOTIFICATIONS),
        REQUEST_CODE_NOTIFICATIONS
    )
}

Запрашиваем в нужный момент контекста — не при первом запуске приложения, а когда пользователь включает нотификации в настройках.

Жизненный цикл токена

onNewToken вызывается при первой регистрации и при обновлении токена (переустановка, очистка данных, обновление Google Play Services). Токен нужно всегда сохранять на сервер. При отправке на устаревший токен FCM возвращает INVALID_REGISTRATION или NOT_REGISTERED — сервер должен удалять такие токены.

Получить текущий токен вручную:

FirebaseMessaging.getInstance().token.addOnCompleteListener { task ->
    if (task.isSuccessful) {
        val token = task.result
        // Отправляем на сервер при каждом запуске (для надёжности)
    }
}

Теги и подписки на топики

Для широковещательных уведомлений (всем пользователям или группе) — FCM Topics:

FirebaseMessaging.getInstance().subscribeToTopic("news")
    .addOnCompleteListener { task ->
        if (task.isSuccessful) Log.d("FCM", "Subscribed to news topic")
    }

Отправка на топик на сервере: "to": "/topics/news". Delivery в течение минут, не гарантированно единоразово.

Что входит в работу

  • Подключение Firebase SDK, google-services.json
  • FirebaseMessagingService с data-message обработкой
  • Notification Channels с правильными параметрами
  • Белая иконка уведомления
  • Запрос разрешения POST_NOTIFICATIONS на Android 13+
  • Lifecycle токена с обновлением на сервере
  • Обработка tap на уведомление: навигация к нужному экрану
  • Topics для групповых уведомлений

Сроки

Базовая интеграция FCM с alert-уведомлениями: 1 день. С data-message обработкой, кастомными каналами, навигацией по payload и lifecycle токена: 1,5–2 дня.