Rba*_*bar 6 ios firebase swift firebase-cloud-messaging firebase-notifications
我正在尝试使用FCM令牌从firebase通知控制台向特定设备发送简单的推送通知.firebase通知控制台将通知显示为已发送但设备未收到通知.我已经尝试发送通知,然后等待查看控制台是否记录didReceiveRemoteNotification,但通知需要花费太长时间(小时)才能显示为在firebase控制台中发送(即使我将优先级设置为high).
App代表
import UIKit
import Firebase
import FirebaseStorage
import FirebaseDatabase
import FirebaseMessaging
import CoreData
import UserNotifications
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate, UNUserNotificationCenterDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
// Use Firebase library to configure APIs
FirebaseApp.configure()
/////
// For Firebase Cloud Messaging (FCM)
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()
// End of [for Firebase Cloud Messaging (FCM)]
/////
return true
}
///////////////////////
// FCM Setup
// Monitor token generation for FCM: Be notified whenever the FCM token is updated
func messaging(_ messaging: Messaging, didRefreshRegistrationToken fcmToken: String) {
print("Firebase registration token: \(fcmToken)")
}
// Monitor token generation for FCM:
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
Messaging.messaging().apnsToken = deviceToken
} // Handle messages received through the FCM APNs interface
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any]) {
print("didReceiveRemoteNotification")
// If you are receiving a notification message while your app is in the background,
// this callback will not be fired till the user taps on the notification launching the application.
// TODO: Handle data of notification
// With swizzling disabled you must let Messaging know about the message, for Analytics
// Messaging.messaging().appDidReceiveMessage(userInfo)
// Print message ID.
// gcm_message_id
if let messageID = userInfo["gcmMessageIDKey"] {
print("Message ID: \(messageID)")
}
Run Code Online (Sandbox Code Playgroud)
^我的猜测是该问题可能与"gcm_message_id"/"gcmMessageId"/"gcm.message_id"有关,因为我在下面尝试的三种方法中的每种方法都不同
// Print full message.
print(userInfo)
}
// Handle messages received through the FCM APNs interface
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
print("didReceiveRemoteNotification (withCompletionHandeler)")
// If you are receiving a notification message while your app is in the background,
// this callback will not be fired till the user taps on the notification launching the application.
// TODO: Handle data of notification
// With swizzling disabled you must let Messaging know about the message, for Analytics
// Messaging.messaging().appDidReceiveMessage(userInfo)
// Print message ID.
if let messageID = userInfo["gcmMessageIDKey"] {
print("Message ID: \(messageID)")
}
Run Code Online (Sandbox Code Playgroud)
^我的猜测是该问题可能与"gcm_message_id"/"gcmMessageId"/"gcm.message_id"有关,因为我在下面尝试的三种方法中的每种方法都不同
// Print full message.
print(userInfo)
completionHandler(UIBackgroundFetchResult.newData)
}
// End of [FCM Setup]
///////////////////////
}
Run Code Online (Sandbox Code Playgroud)
查看控制器
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Retrieve the current registration token for Firebase Cloud Messaging (FCM)
let token = Messaging.messaging().fcmToken
print("FCM token: \(token ?? "")")
}
}
Run Code Online (Sandbox Code Playgroud)
权利和启用推送通知
我添加了推送权利
并启用推送通知的后台模式
并将GoogleService-Info.plist添加到我的项目中.
发送通知的方法
我正在从Firebase Notifications控制台创建通知(如下所示),因此通知本身的结构应该没有问题.

我尝试了以下方法来解决问题,但所有方法都产生了相同的结果:
有谁知道为什么通知被标记为在firebase通知控制台中发送但未显示在设备上?
尝试将以下代码添加到 didRegisterForRemoteNotificationsWithDeviceToken func:
Messaging.messaging().apnsToken = deviceToken
Run Code Online (Sandbox Code Playgroud)
所以它看起来像这样:
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
Messaging.messaging().apnsToken = deviceToken
}
Run Code Online (Sandbox Code Playgroud)
这对我来说是工作。
我在处理推送通知时使用的几个故障排除步骤如下:
我希望这可以帮助你,因为你工作得到了所有想通.
| 归档时间: |
|
| 查看次数: |
9050 次 |
| 最近记录: |