Push Notifications are delivered but didReceiveRemoteNotification is never called Swift(推送通知已交付,但 didReceiveRemoteNotification 从未被称为 Swift)
问题描述
我已通过 FCM 在我的两个相关应用中成功实现推送通知,并尝试实现一些逻辑以在收到通知时增加徽章编号.
I have successfully implemented push notifications in my two related apps via FCM and while trying to implement some logic to increment badge number on receiving the notification.
我意识到 didReceiveRemoteNotificationdelegate 方法根本没有被调用,因为我没有得到任何打印结果,但我确实从 willPresent 通知和 didReceive 响应.所以在 didFinishLaunchingWithOptions 中设置 UIApplication.shared.applicationIconBadgeNumber 没有效果,但是在里面设置 didReceive response 可以.
I realized that didReceiveRemoteNotificationdelegate method is not called at all as I don't get any prints out of it, but I do get prints from willPresent notificationand didReceive response. So setting UIApplication.shared.applicationIconBadgeNumber in didFinishLaunchingWithOptionshas no effect, but setting in it didReceive responsedoes.
按照文档 didReceiveRemoteNotification 应该被调用,但是当通知到达时我从来没有打印出来.
Following the documentation didReceiveRemoteNotification should be called but I never get prints out of it when a notification arrives.
我尝试将整个 didReceiveRemoteNotification 方法注释掉,并且通知仍然传递.
I tried commenting out the whole didReceiveRemoteNotificationmethod and notifications are still delivered.
为什么会这样?我想我真的不明白谁在这个设置中处理消息.你能帮我澄清一下吗?
Why is it so? I guess I didn't really understand who's handling messaging in this set up. Can you please help me clarifying it?
AppDelegate 方法:
AppDelegate methods:
didFinishLaunchingWithOptions:
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
window?.tintColor = UIColor.blue
// Use Firebase library to configure APIs
FirebaseApp.configure()
Messaging.messaging().delegate = self
Crashlytics().debugMode = true
Fabric.with([Crashlytics.self])
// setting up notification delegate
if #available(iOS 10.0, *) {
//iOS 10.0 and greater
UNUserNotificationCenter.current().delegate = self
let authOptions: UNAuthorizationOptions = [.alert, .badge, .sound]
//Solicit permission from the user to receive notifications
UNUserNotificationCenter.current().requestAuthorization(options: authOptions, completionHandler: { granted, error in
DispatchQueue.main.async {
if granted {
print("didFinishLaunchingWithOptions iOS 10: Successfully registered for APNs")
UIApplication.shared.registerForRemoteNotifications()
// UIApplication.shared.applicationIconBadgeNumber = 1
AppDelegate.badgeCountNumber = 0
UIApplication.shared.applicationIconBadgeNumber = 0
} else {
//Do stuff if unsuccessful...
print("didFinishLaunchingWithOptions iOO 10: Error in registering for APNs: (String(describing: error))")
}
}
})
} else {
//iOS 9
let type: UIUserNotificationType = [UIUserNotificationType.badge, UIUserNotificationType.alert, UIUserNotificationType.sound]
let setting = UIUserNotificationSettings(types: type, categories: nil)
UIApplication.shared.registerUserNotificationSettings(setting)
UIApplication.shared.registerForRemoteNotifications()
// UIApplication.shared.applicationIconBadgeNumber = 1
UIApplication.shared.applicationIconBadgeNumber = 0
print("didFinishLaunchingWithOptions iOS 9: Successfully registered for APNs")
}
// setting up remote control values
let _ = RCValues.sharedInstance
GIDSignIn.sharedInstance().clientID = FirebaseApp.app()?.options.clientID
Crashlytics().debugMode = true
Fabric.with([Crashlytics.self])
// // TODO: Move this to where you establish a user session
// self.logUser()
var error: NSError?
do {
try AVAudioSession.sharedInstance().setCategory(AVAudioSessionCategoryPlayback)
} catch let error1 as NSError{
error = error1
print("could not set session. err:(error!.localizedDescription)")
}
do {
try AVAudioSession.sharedInstance().setActive(true)
} catch let error1 as NSError{
error = error1
print("could not active session. err:(error!.localizedDescription)")
}
// goggle only
GIDSignIn.sharedInstance().clientID = FirebaseApp.app()?.options.clientID
// GIDSignIn.sharedInstance().delegate = self
// Facebook SDK
return FBSDKApplicationDelegate.sharedInstance().application(application, didFinishLaunchingWithOptions: launchOptions)
// return true
}
didReceiveRemoteNotification:
// foreground
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any]) {
print("didReceiveRemoteNotification: Received new push Notification")
// 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)
AppDelegate.badgeCountNumber += userInfo["badge"] as! Int
print("AppDelegate.badgeCountNumber is : (String(describing: AppDelegate.badgeCountNumber))")
// UIApplication.shared.applicationIconBadgeNumber = AppDelegate.badgeCountNumber
UIApplication.shared.applicationIconBadgeNumber = 10//AppDelegate.badgeCountNumber
// Print full message.
print("didReceiveRemoteNotification: Push notificationMessage is: (userInfo)")
}
// background
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any],
fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
print("didReceiveRemoteNotification with handler : Received new push Notification while in background")
// 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)
if let messageID = userInfo[ userDetails.fcmToken] { // working for looged in
print("didReceiveRemoteNotification: Message ID: (messageID)")
}
// Print full message.
print("didReceiveRemoteNotification: Push notificationMessage is: (userInfo)")
AppDelegate.badgeCountNumber += userInfo["badge"] as! Int
print("AppDelegate.badgeCountNumber is : (String(describing: AppDelegate.badgeCountNumber))")
UIApplication.shared.applicationIconBadgeNumber += userInfo["badge"] as! Int
completionHandler(UIBackgroundFetchResult.newData)
}
推荐答案
我终于找到了解决方案.警报需要"content_available": true 在从 App2 到 App1 的帖子发送功能的警报定义中设置,否则会传递通知但不调用didReceiveRemoteNotification",您不能使用userInfo"'.希望这对其他人有所帮助,因为我没有找到有关此问题的太多信息.如果您使用 Postman 或类似工具设置通知,请在此处查看 didReceiveRemoteNotification 函数不使用 FCM 通知服务器调用,因为这是我在这个问题上找到的唯一帖子并解决了我的问题.感谢@Ranjani 尝试帮助我.
I finally found the solution. Alert needs"content_available": true to be set in the alert definition from the post sending funtion from App2 to App1 or else notifications get delivered but 'didReceiveRemoteNotification` is not called and you can't use 'userInfo'. Hope this will help others as I haven't found much info about this problem. If you're setting the notification with Postman or similars check here didReceiveRemoteNotification function doesn't called with FCM notification server as that's the only post I found on this problem and solved mine.
Thanks to @Ranjani for trying helping me.
let postParams: [String : Any] = [
"to": receiverToken,
"notification": [
"badge" : 1,
"body": body,
"title": title,
"subtitle": subtitle,
"sound" : true, // or specify audio name to play
"content_available": true, // this will call didReceiveRemoteNotification in receiving app, else won't work
"priority": "high"
],
"data" : [
"data": "ciao",
]
]
这篇关于推送通知已交付,但 didReceiveRemoteNotification 从未被称为 Swift的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:推送通知已交付,但 didReceiveRemoteNotification 从未被称为 Swift
基础教程推荐
- 通过重定向链接在 Google Play 中打开应用 2022-01-01
- AdMob 广告未在模拟器中显示 2022-01-01
- iPhone - 获取给定地点/时区的当前日期和时间并将其与同一地点的另一个日期/时间进行比较的正确方法 2022-01-01
- libGDX 从精灵或纹理中获取像素颜色 2022-01-01
- navigator.geolocation.getCurrentPosition 在 Android 浏览器上 2022-01-01
- Cocos2d iPhone 非矩形精灵触摸检测 2022-01-01
- NSString intValue 不能用于检索电话号码 2022-01-01
- iOS4 创建后台定时器 2022-01-01
- 如何从 logcat 中删除旧数据? 2022-01-01
- Android:getLastKnownLocation(LocationManager.NETWORK_PROVIDER 2022-01-01
