Отправка изображения в полезных данных уведомления

API FCM HTTP v1 и композитор уведомлений поддерживают отправку ссылок на изображения в полезных данных уведомления об отображении для загрузки изображения на устройство после доставки. Размер изображений для уведомлений ограничен 1 МБ, а в остальном они ограничены встроенной поддержкой изображений Android.

Создайте запрос на отправку

В запросе на отправку уведомления установите следующий параметр AndroidConfig :

  • notification.image содержащий URL-адрес изображения

В следующем примере запроса на отправку на все платформы отправляется общий заголовок уведомления, а также изображение. Вот приблизительный визуальный эффект на устройстве пользователя:

Простое рисование изображения в уведомлении о показе

Node.js

const topicName = 'industry-tech';

const message = {
  notification: {
    title: 'Sparky says hello!'
  },
  android: {
    notification: {
      imageUrl: 'https://foo.bar.pizza-monster.png'
    }
  },
  apns: {
    payload: {
      aps: {
        'mutable-content': 1
      }
    },
    fcm_options: {
      image: 'https://foo.bar.pizza-monster.png'
    }
  },
  webpush: {
    headers: {
      image: 'https://foo.bar.pizza-monster.png'
    }
  },
  topic: topicName,
};

getMessaging().send(message)
  .then((response) => {
    // Response is a message ID string.
    console.log('Successfully sent message:', response);
  })
  .catch((error) => {
    console.log('Error sending message:', error);
  });

ОТДЫХ

POST https://fcm.googleapis.com/v1/projects/myproject-b5ae1/messages:send HTTP/1.1

Content-Type: application/json
Authorization: Bearer ya29.ElqKBGN2Ri_Uz...HnS_uNreA
{
  "message":{
     "topic":"industry-tech",
     "notification":{
       "title":"Sparky says hello!",
     },
     "android":{
       "notification":{
         "image":"https://foo.bar/pizza-monster.png"
       }
     },
     "apns":{
       "payload":{
         "aps":{
           "mutable-content":1
         }
       },
       "fcm_options": {
           "image":"https://foo.bar/pizza-monster.png"
       }
     },
     "webpush":{
       "headers":{
         "image":"https://foo.bar/pizza-monster.png"
       }
     }
   }
 }

Подробную информацию о ключах, доступных в блоках для конкретной платформы в теле сообщения, см. в справочной документации HTTP v1.

Если notification установлено, как показано, этот запрос на отправку позволяет принимающему клиенту обрабатывать изображение, доставленное в полезной нагрузке.