Arhn - архитектура программирования

Push-уведомления IOS GCM не получены в фоновом режиме с использованием отправителя PHP и Swift

Я работаю над тем, чтобы фоновые уведомления работали на IOS с GCM — нефоновые уведомления уже работают. Вот мои шаги по интеграции фоновых уведомлений:

  1. Включите тег удаленных уведомлений в UIBackgroundmodes.
  2. Добавьте ключ доступа к содержимому в полезную нагрузку моего уведомления.
  3. Напишите приложение: didRecieveRemoteNotification: fetchCompletionHandler: в моем делегате.

Вот код функции делегата:

func application( application: UIApplication,
    didReceiveRemoteNotification userInfo: [NSObject : AnyObject],
    fetchCompletionHandler handler: (UIBackgroundFetchResult) -> Void) {
        println("Notification received2: \(userInfo)")

        GCMService.sharedInstance().appDidReceiveMessage(userInfo);

        NSNotificationCenter.defaultCenter().postNotificationName(messageKey, object: nil,
            userInfo: userInfo)
        handler(UIBackgroundFetchResult.NoData);    
}

Это код для php-скрипта на сервере:

<?php
$regId = $_GET["regId"];
$message = $_GET["message"];

$data = array( 'price' => $message, 'sound' => 'default', 'body' => 'helloworld', 'title' => 'default', 'badge' => 12, 'content-available' => 1);

$ids = array( $regId);

sendGoogleCloudMessage(  $data, $ids );

function sendGoogleCloudMessage( $data, $ids )
{

    $apiKey = THE-API-KEY-THAT-I-AM-USING;

    $url = 'https://android.googleapis.com/gcm/send';

    $post = array(
                'registration_ids'  => $ids,
                'data'              => $data,
                'content-available' => 1,
    );

    $headers = array(
                    'Authorization: key=' . $apiKey,
                    'Content-Type: application/json'
                );

    $ch = curl_init();

    curl_setopt( $ch, CURLOPT_URL, $url );

    curl_setopt( $ch, CURLOPT_POST, true );

    curl_setopt( $ch, CURLOPT_HTTPHEADER, $headers );

    curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true );

    curl_setopt( $ch, CURLOPT_POSTFIELDS, json_encode( $post ) );

    $result = curl_exec( $ch );

    if ( curl_errno( $ch ) )
    {
        echo 'GCM error: ' . curl_error( $ch );
    }

    curl_close( $ch );

    echo $result;
}
?>

Я попытался отправить флаг доступности содержимого как через внутренний массив «данные», так и через внешний массив «сообщений», который я указал, добавив его к обоим.

Сообщение не принимается функцией fetchCompletionHandler, а ожидает, пока приложение снова станет активным, и будет получено обычной функцией application:didRecieveRemoteNotification. Что может быть причиной того, что мое уведомление не приходит в фоновом режиме?

13.07.2015

Ответы:


1

Вы должны предоставить GCM доступный_контент, а не доступный_контент (как в APN), и вы сможете получать push-уведомления в фоновом режиме.

https://developers.google.com/cloud-messaging/server-ref#send-downstream

P.S. - Меньше пяти минут назад у меня была абсолютно такая же проблема. Нам следует более внимательно читать документы...

17.07.2015
  • Спасибо большое! Это определенно было проблемой - однако, когда я добавляю правильный тег, теперь ни одна из функций приемника не вызывается. Есть идеи, почему? 20.07.2015
  • @JohnSzymanski, вы также должны добавить тег fetch в UIBackgroundModes. 21.07.2015
  • Кажется, ничего не меняется. . . 22.07.2015
  • @JohnSzymanski, даже если ваше приложение находится на переднем плане? content_available должен быть в массиве $post, а не в разделе data. Кроме того, вы не можете получить удаленное уведомление, пока наше приложение не запущено (убито через переключатель приложений). В этом случае единственный способ показать уведомление пользователю — добавить секцию notification в массив $post. 23.07.2015
  • Спасибо Олег! На самом деле я пытался добавить раздел уведомлений и иметь доступ к контенту в разделе сообщений - добавление любого из них останавливает получение уведомлений либо на переднем плане, либо на заднем плане, даже если у меня все еще есть массив данных. 24.07.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..