iOS FCM 推送通知在后台状态下无法快速工作?

B.S*_*mar 0 push-notification ios firebase swift firebase-cloud-messaging

在我的应用程序中,我实现了 FCM 推送通知。当使用 FCM 控制台和 pushtry.com 网站检查通知时,它工作正常,然后我尝试使用实际的服务器 API,前台通知运行良好,但后台通知未收到,有时它很少收到,而且没有横幅和声音。请帮助找出问题。

在这里,我附上了我正在尝试的代码。

import UIKit
import UserNotifications
import Firebase

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

var window: UIWindow?

func application(_ application: UIApplication,
             didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
FirebaseApp.configure()

Messaging.messaging().delegate = self
if #available(iOS 10.0, *) {
    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()
return true
}
func application(_ application: UIApplication, 
didReceiveRemoteNotification userInfo: [AnyHashable: Any]) {

print(userInfo)
}
func applicationDidBecomeActive(_ application: UIApplication)
{
    Messaging.messaging().shouldEstablishDirectChannel = true

    application.applicationIconBadgeNumber = 0;
}

func applicationDidEnterBackground(_ application: UIApplication)
{
    Messaging.messaging().shouldEstablishDirectChannel = false
    print("Disconnected from FCM.")
}
func application(_ application: UIApplication, 
didReceiveRemoteNotification userInfo: [AnyHashable: Any],
             fetchCompletionHandler completionHandler: @escaping 
(UIBackgroundFetchResult) -> Void) {

print(userInfo)

completionHandler(UIBackgroundFetchResult.newData)
}
func application(_ application: UIApplication, 
didFailToRegisterForRemoteNotificationsWithError error: Error) {
print("Unable to register for remote notifications: \ . 
(error.localizedDescription)")
}
func application(_ application: UIApplication, 
didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
print("APNs token retrieved: \(deviceToken)")

}
}

@available(iOS 10, *)
extension AppDelegate : UNUserNotificationCenterDelegate {

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

completionHandler([])
}

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

completionHandler()
}
}

extension AppDelegate : MessagingDelegate {
func messaging(_ messaging: Messaging, didRefreshRegistrationToken 
fcmToken: String) {
  print("Firebase registration token: \(fcmToken)")
}
func messaging(_ messaging: Messaging, didReceive remoteMessage: 
MessagingRemoteMessage) {
  print("Received data message: \(remoteMessage.appData)")
}
}
Run Code Online (Sandbox Code Playgroud)

这里我分享了服务器推送通知的请求格式:

{
"to":"cerGBjsmtzE:APA91bFk- 
 6ZI4ehaWbg0bGSGzAh10NeUh3AcyEFq7dASU7W4YY4WL8vWCA5wav- 
 LTYc0xTGWHev8Z99",
 "priority":"high",
"data":
  {
    "title":"New Inspection scheduled",
    "body":"You have a new Inspection Request scheduled,
    "sound":"default"
  }
}
Run Code Online (Sandbox Code Playgroud)

Kam*_*waj 5

确保您在后台模式下选择了远程设置---在 XCODE 的功能部分下

参考