所以我一直在这里和其他地方阅读有关该主题的其他文章,但我仍在努力。我的应用正在使用"Fireabase FCM"
进行设备到设备的通知。我能够发送和接收消息。但是,永远不会调用方法"didReceive remoteMessage"
。我想使用此功能来更新应用程序和标签栏项的徽章编号。
我尝试添加其他方法来指示已接收到消息,但这些方法均无效。我想我缺少基本的东西。我在Swift 5
中使用Xcode 10
。
import Foundation
import UIKit
import Firebase
import FirebaseFirestore
import FirebaseMessaging
import UserNotifications
class PushNotificationManager : NSObject, MessagingDelegate, UNUserNotificationCenterDelegate {
static let shared = PushNotificationManager( )
var userID: String = ""
var instanceIDToken : String = ""
let defaults = UserDefaults.standard
override init( ) {
super.init()
}
func setUserId(identifier: String) {
userID = identifier
}
func registerForPushNotifications() {
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 })
// For iOS 10 data message (sent via FCM)
Messaging.messaging().delegate = self
} else {
let settings: UIUserNotificationSettings =
UIUserNotificationSettings(types: [.alert, .badge, .sound], categories: nil)
UIApplication.shared.registerUserNotificationSettings(settings)
}
UIApplication.shared.registerForRemoteNotifications()
UNMutableNotificationContent().sound = UNNotificationSound.default
Messaging.messaging().shouldEstablishDirectChannel = true
updateFirestorePushTokenIfNeeded()
}
func getNotificationSettings( ) {
UNUserNotificationCenter.current().getNotificationSettings { (settings) in
print("Notification settings: \(settings)")
guard settings.authorizationStatus == .authorized else {return}
DispatchQueue.main.async{UIApplication.shared.registerForRemoteNotifications()}
}
}
func updateFirestorePushTokenIfNeeded( ) {
// let mytoken = Messaging.messaging().fcmToken
if let token = Messaging.messaging().fcmToken {
let usersRef = Firestore.firestore().collection("users_table").document(userID)
usersRef.setData(["fcmToken": token], merge: true)
}
}
func messaging(_ messaging: Messaging, didReceive remoteMessage: MessagingRemoteMessage) {
print(remoteMessage.appData)
}
func application(received remoteMessage: MessagingRemoteMessage) {
print("applicationReceivedRemoteMessage")
print(remoteMessage.appData)
}
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any]) {
print("REMOTE NOTIFICATION RECEIVED")
}
func messaging(_ messaging: Messaging, didReceiveRegistrationToken fcmToken: String) {
print("Firebase registration token: \(fcmToken)")
updateFirestorePushTokenIfNeeded()
}
func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void) {
print(response)
}
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
completionHandler([.alert, .sound])
}
func getTokenDirectly( ) {
InstanceID.instanceID().instanceID { (result, error) in
if let error = error {
print("Error fetching remote instance ID: \(error)")
} else if let result = result {
print("Remoted instance ID token: \(result.token)")
self.instanceIDToken = result.token
self.updateFirestorePushTokenIfNeeded()
}
}
}
}
同样,我会在要测试的设备上收到通知,
func messaging(_ messaging: Messaging, didReceive remoteMessage: MessagingRemoteMessage) {
print(remoteMessage.appData)
}
从未被调用。
最佳答案
似乎您没有调用此方法:
registerForPushNotifications()
因为那是您将
delegate
设置为self
委托的方法的地方不会被要求