Pu sh уведомления не работают Xcode 11.3.1 - PullRequest
1 голос
/ 10 февраля 2020

Вот моя ситуация: я сгенерировал производственный сертификат уведомлений pu sh. На портале разработчика Apple сертификат выглядит как:

У меня есть сертификат Apple Dev и сертификат распространения Apple:

Я создаю архив и распространяю свое приложение с Ad Ho c, используя Xcode 11.3.1. Вот краткое описание объявления c:

enter image description here

Я включил уведомления pu sh, но они не работают. Я не могу получать уведомления, когда приложение находится в фоновом режиме. Когда я использовал сертификат распространения iPhone в Xcode 10.3, уведомления работали с тем же кодом. Что мне не хватает? Thx !!

1 Ответ

2 голосов
/ 10 февраля 2020

Вот процесс интеграции уведомления pu sh, следуйте ему шаг за шагом:

Сначала войдите в свою учетную запись разработчика Apple -> Идентификаторы -> щелкните идентификатор приложения и включите уведомление pu sh , После включения уведомления у вас будет запрошен CertificateSigningRequest.certSigningRequest. Вам необходимо открыть доступ к Цепочке для ключей и открыть enter image description here нажмите Ассистент сертификации -> Запросить сертификат у центра сертификации

После создания этого сертификата вы нужно добавить, что сертификаты в учетной записи Apple. И загрузите оттуда сертификаты развития и сертификации.

После загрузки этих сертификатов просто нажмите на оба сертификата, и это откроет ваш брелок Access. Теперь щелкните левой кнопкой мыши на этом сертификате и экспортируйте сертификат .p12, который попросит вас сгенерировать пароль для этого сертификата.

Теперь откройте свою учетную запись firebase и go в настройках -> облачные сообщения -> добавьте ваш production.p12 и там есть сертификат development.p12.

Теперь вернемся к xcode Go к цели приложения -> Вход и возможности -> добавьте уведомления pu sh и добавьте фоновые режимы, проверьте выборку фона и удаленное уведомление.

Приходите к коду, теперь добавьте модули и установите

pod 'Firebase/Analytics' 
pod 'Firebase/Messaging'

Откройте свой AppDelegate, импортируйте эти

import FirebaseAnalytics
import Firebase
import FirebaseMessaging

Добавьте делегата MessagingDelegate

Инициируйте let gcmMessageIDKey = "gcm.message_id"

Добавьте их в didFinishLaunchingWithOptions метод

       FirebaseApp.configure()

        Messaging.messaging().delegate = self
        //Added push notification

        if #available(iOS 10.0, *) {
                 // For iOS 10 display notification (sent via APNS)
             UNUserNotificationCenter.current().delegate = self

             let authOptions: UNAuthorizationOptions = [.alert, .badge, .sound]
             UNUserNotificationCenter.current().requestAuthorization(
                 options: authOptions,
                 completionHandler: {_, _ in })
         } else {
             let settings: UIUserNotificationSettings =
                 UIUserNotificationSettings(types: [.alert, .badge, .sound], categories: nil)
             application.registerUserNotificationSettings(settings)
         }

         application.registerForRemoteNotifications()

         Messaging.messaging().isAutoInitEnabled = true

После добавления добавьте эти методы в делегат приложения, и вы готовы получать уведомления pu sh:

//Push Notifications

   func application(application: UIApplication,
                       didRegisterForRemoteNotificationsWithDeviceToken deviceToken: NSData) {
          Messaging.messaging().apnsToken = deviceToken as Data
      }
      func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any]) {

          InstanceID.instanceID().instanceID { (result, error) in
              if let error = error {
                  print("Error fetching remote instance ID: \(error)")
              } else if let result = result {
                  print("Remote instance ID token: \(result.token)")
                  //  self.instanceIDTokenMessage.text  = "Remote InstanceID token: \(result.token)"
              }
          }

          print(userInfo)
      }

      func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any],
                       fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {

          if let messageID = userInfo[gcmMessageIDKey] {
              print("Message ID: \(messageID)")
          }

          print(userInfo)

          completionHandler(UIBackgroundFetchResult.newData)
      }

    func userNotificationCenter(_ center: UNUserNotificationCenter,
                                   willPresent notification: UNNotification,
                                   withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
           let userInfo = notification.request.content.userInfo

           if let messageID = userInfo[gcmMessageIDKey] {
               print("Message ID: \(messageID)")
           }

           completionHandler([])
       }

       func userNotificationCenter(_ center: UNUserNotificationCenter,
                                   didReceive response: UNNotificationResponse,
                                   withCompletionHandler completionHandler: @escaping () -> Void) {
           let userInfo = response.notification.request.content.userInfo

           if let messageID = userInfo[gcmMessageIDKey] {
               print("Message ID: \(messageID)")
           }

           print(userInfo)

           completionHandler()
       }


       func messaging(_ messaging: Messaging, didReceiveRegistrationToken fcmToken: String) {
           print("Firebase registration token: \(fcmToken)")
           let dataDict:[String: String] = ["token": fcmToken]


           NotificationCenter.default.post(name: Notification.Name("FCMToken"), object: nil, userInfo: dataDict)

           UserDefaults.standard.set(fcmToken, forKey: "FCMToken")
           UserDefaults.standard.synchronize()

       }

       func messaging(_ messaging: Messaging, did remoteMessage: MessagingRemoteMessage) {
           print("Received data message: \(remoteMessage.appData)")
       }

       func messaging(_ messaging: Messaging, didReceive remoteMessage: MessagingRemoteMessage) {
           print("Received data message: \(remoteMessage.appData)")
       }

       func application(_ application: UIApplication,
                        didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
           Messaging.messaging().apnsToken = deviceToken as Data

       }

       func messaging(_ messaging: Messaging, didRefreshRegistrationToken fcmToken: String) {
           print("Firebase registration token: \(fcmToken)")

           let dataDict:[String: String] = ["token": fcmToken]



       }
...