MacCatalyst 上未调用 didReceiveRemoteNotification
didReceiveRemoteNotification not being called on MacCatalyst
当我创建 CKSubscription 时,didReceiveRemoteNotification 会在 iOS 上正常调用,但在 MacOS 上不会。我遇到了一个 2015 SO 线程谈论一个错误,建议的解决方法是将通知信息的 soundName 设置为空字符串 - 不幸的是,这并没有解决我的问题。
以下是我注册远程通知的方式:
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
let subscription = CKQuerySubscription(recordType: "Reminder", predicate: NSPredicate(format: "TRUEPREDICATE"), options: [.firesOnRecordCreation, .firesOnRecordUpdate])
// Here we customize the notification message
let info = CKSubscription.NotificationInfo()
info.shouldSendContentAvailable = true
info.desiredKeys = ["identifier", "title", "date"]
info.soundName = ""
subscription.notificationInfo = info
// Save the subscription to Private Database in Cloudkit
CKContainer.default().privateCloudDatabase.save(subscription, completionHandler: { subscription, error in
if error == nil {
// Subscription saved successfully
} else {
// Error occurred
}
})
}
这与 Mac Catalyst 上的包标识符不同有关。多亏了即将推出的通用应用程序购买功能,Catalyst 应用程序现在可以使用与其对应的 iOS 相同的捆绑包标识符,这解决了这个问题。
请注意,我还遇到了 cloudkit 键值未在 Mac (NSUbiquitousKeyValueStore) 上同步的问题。 Mac 和 iOS 有一个包 ID 也解决了这个问题。
当我创建 CKSubscription 时,didReceiveRemoteNotification 会在 iOS 上正常调用,但在 MacOS 上不会。我遇到了一个 2015 SO 线程谈论一个错误,建议的解决方法是将通知信息的 soundName 设置为空字符串 - 不幸的是,这并没有解决我的问题。
以下是我注册远程通知的方式:
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
let subscription = CKQuerySubscription(recordType: "Reminder", predicate: NSPredicate(format: "TRUEPREDICATE"), options: [.firesOnRecordCreation, .firesOnRecordUpdate])
// Here we customize the notification message
let info = CKSubscription.NotificationInfo()
info.shouldSendContentAvailable = true
info.desiredKeys = ["identifier", "title", "date"]
info.soundName = ""
subscription.notificationInfo = info
// Save the subscription to Private Database in Cloudkit
CKContainer.default().privateCloudDatabase.save(subscription, completionHandler: { subscription, error in
if error == nil {
// Subscription saved successfully
} else {
// Error occurred
}
})
}
这与 Mac Catalyst 上的包标识符不同有关。多亏了即将推出的通用应用程序购买功能,Catalyst 应用程序现在可以使用与其对应的 iOS 相同的捆绑包标识符,这解决了这个问题。
请注意,我还遇到了 cloudkit 键值未在 Mac (NSUbiquitousKeyValueStore) 上同步的问题。 Mac 和 iOS 有一个包 ID 也解决了这个问题。