【发布时间】:2017-09-27 13:36:44
【问题描述】:
问题是通知服务扩展本身没有用,除了在应用程序被杀死时可以显示的一件事。因此,通过应用内通知和内容扩展,我可以显示自定义通知,但只有在应用未被杀死/强制关闭时才会显示该通知。 问题:如果有内容和服务通知扩展,如何管理应用内通知,以及如何强制通知服务扩展调用/唤醒通知内容扩展。
【问题讨论】:
标签: ios notifications apple-push-notifications
问题是通知服务扩展本身没有用,除了在应用程序被杀死时可以显示的一件事。因此,通过应用内通知和内容扩展,我可以显示自定义通知,但只有在应用未被杀死/强制关闭时才会显示该通知。 问题:如果有内容和服务通知扩展,如何管理应用内通知,以及如何强制通知服务扩展调用/唤醒通知内容扩展。
【问题讨论】:
标签: ios notifications apple-push-notifications
似乎我需要清理项目并删除应用程序并重新安装。这是 FCM 实现这种情况的完整步骤,可能有些步骤是多余的,但我不想在它工作的时候碰它:
应用程序被杀死/关闭:通知出现在自定义内容视图中 应用程序在后台:通知出现在自定义内容视图中 应用程序在前台:通知以静默方式到达
从服务器端,通知应如下所示
{ “通知”://强制 { “数据”:{}, "body":""//似乎也是必须的,无论如何你可以在服务扩展中更改它 } "content_available":true,//强制 "mutable_content":true,//强制 "to":""//必填项 }
创建通知服务扩展目标。
在 NotificationService 中的 didReceive 中获取可变内容
bestAttemptContent = (request.content.mutableCopy() as?UNMutableNotificationContent)
将您的类别添加到内容中
bestAttemptContent.categoryIdentifier = "yourCategory"
调用contentHandler(bestAttemptContent) 后会出现标准通知。
创建通知内容扩展目标。
notification.request.content.userInfo["gcm.notification.data"] 中。所以在 NotificationViewController 中用数据填充视图。不要忘记preferredContentSize。UNUserNotificationCenterDelegate。在didFinishLaunchingWithOptions添加
UNUserNotificationCenter.current().delegate = self UNUserNotificationCenter.current().requestAuthorization(options: [.badge, .alert, .sound]) { (granted, error) in } application.registerForRemoteNotifications()
在 AppDelegate 中添加
func application(_application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken 设备令牌:数据){ Messaging.messaging().apnsToken = deviceToken }
在 userNotificationCenter willPresent 检查您的应用程序是否未运行。我是这样弄的:
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent 通知: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) { 如果 self.window?.rootViewController == nil { 完成处理程序([.badge,.alert,.sound]) } UIApplication.shared.applicationIconBadgeNumber = UIApplication.shared.applicationIconBadgeNumber + 1 }
在此处处理静默通知:
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void)
func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void)
这里你可以用同样的方式response.notification.request.content.userInfo["gcm.notification.data"]获取自定义数据
func application(_ application: UIApplication, handleEventsForBackgroundURLSession identifier: String, completionHandler: @escaping () -> Void)
似乎仅此而已:)。啊,扩展程序从 IOS 10 开始工作。如果缺少某些内容或某些内容是多余的,请纠正我。
【讨论】: