在后台应用时,使用推送通知更新徽章

问题描述 投票:59回答:10

我有推送通知工作,并设法更新图标徽章计数当应用程序被带到前台。

我对此有点困惑...虽然iPhone收到通知,但弹出消息似乎激活我的应用程序,并且徽章仅在我启动应用程序后更新。

这在用户体验方面听起来不对。我的理解是,徽章计数应该通过增加的计数通知用户需要采取什么行动,但这种情况不会发生在应用程序生效的后期阶段。

那么有没有办法告诉应用程序在接收推送通知时和后台时更新其徽章计数?

请注意,我的应用程序不使用位置,并且我在通知注册请求中有UIRemoteNotificationTypeBadge

干杯AF

ios apple-push-notifications
10个回答
62
投票

由于推送通知由iOS而非您的应用程序处理,因此您无法在收到推送通知时更改应用程序徽章。

但您可以在推送通知的有效负载中发送徽章编号,但您必须执行计算服务器端。

你应该阅读Local and Push Notification Programming Guide,尤其是The Notification Payload

有效负载可能如下所示:

{
    "aps" : {
        "alert" : "You got your emails.",
        "badge" : 9
    }
}

现在,应用程序应用程序徽章图标将显示9。


-1
投票

打开App后收到远程通知后,

在你的func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) { // increase badge count, but no need if you include content-available application.applicationIconBadgeNumber = application.applicationIconBadgeNumber + 1 } func applicationDidBecomeActive(_ application: UIApplication) { // reset badge count application.applicationIconBadgeNumber = 0 } 的“"aps":{ "alert":"Test", "sound":"default", "content-available":1 } ”方法中获取当前的徽章编号。

使用以下代码的文件:

didBecomeActive

10
投票

通过在推送通知包中发送“badge”参数,我们可以在处于后台状态时更改徽章编号。正如@rckoenes所指出的那样,徽章的JSON参数必须是INTEGER。

用于执行相同操作的示例PHP代码

// Create the payload body
$body['aps'] = array(
        'alert' => $message,
        'badge' => 1,
        'sound' => 'default'
        );

qazxsw poi其中1是整数而不是字符串(即没有撇号)


6
投票
badge => 1

密钥徽章的值自动被视为徽章计数。在ios应用程序端无需计算或处理计数。在上面的示例中,9是徽章计数。因此,您的应用图标将显示9。

注意当您的应用程序关闭时,您无法自行处理徽章。这就是为什么我们使用APNS Payload的徽章密钥为了更好地说明通知,请参阅文档

如果你想减少自己的徽章数量。减少计数并自己更新。如下


3
投票

如果您使用的是NotificationServiceExtension,则可以更新徽章。

    **This is the APNS payload get back from server.**

    {
        "aps" : {
            "alert" : "You got your emails.",
            "badge" : 9,
            "sound" : "bingbong.aiff"
        },
        "acme1" : "bar",
        "acme2" : 42
    }

每次您的应用程序收到通知时,都会调用您的服务扩展名。将该值保存在用户默认值中并显示它。要在应用程序和扩展之间共享用户默认值,您需要在应用程序中启用应用程序组。 var bestAttemptContent : UNMutableNotificationContent? // bestAttemptContent.badge = 0//any no you wanna display


3
投票

实际上在iOS 10中,远程通知会自动调用AppDelegate中的qazxsw poi方法。

您有两种方法可以在后台更新徽章计数。 我也为我当前的应用程序做了这个。您也不需要通知服务扩展。

1st Way

将带有效负载的APS徽章密钥发送到APN。 这将根据徽章有效负载中的Integer值更新徽章计数。 e.x:

Read more here

2nd Way

您可以切换application.applicationState并更新您的徽章当applicationState位于didReceiveRemoteNotification时计数。但是在发送到APN e.x时,您必须注意不要在通知有效负载中设置徽章密钥参数。

// Payload for remote Notification to APN
{
    "aps": {
        "content-available": 1,
        "alert": "Hallo, this is a Test.",
        "badge": 2, // This is your Int which will appear as badge number,
        "sound": default
    }
}

Handle the badge Update accordingly to the application state

这是我的工作代码,用于在APN的有效负载中没有徽章密钥的徽章计数更新。

.background

Reset badge count

当您的应用恢复活跃状态时,请不要忘记重置徽章计数。

// Payload to APN as silent push notification
{
    "aps": {
        "content-available": 1
    }
}

2
投票

从iOS 10开始,您可以为您的应用开发Notification Service扩展。它会在您收到通知时由系统启动,您可以计算徽章的有效编号并进行设置。

看看文档:func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) { print("APN recieved") // print(userInfo) let state = application.applicationState switch state { case .inactive: print("Inactive") case .background: print("Background") // update badge count here application.applicationIconBadgeNumber = application.applicationIconBadgeNumber + 1 case .active: print("Active") } }


0
投票
func applicationDidBecomeActive(_ application: UIApplication) {
    // reset badge count
    application.applicationIconBadgeNumber = 0
}

0
投票

正如@rckoenes所说,您将不得不进行计算服务器端,但是您怎么知道何时增加应该在有效载荷中发送的徽章编号值?

将在您启动应用程序时向您的服务器发送一条消息,指示该应用程序已启动。因此,在服务器端,您将从badge = 0重新开始,并且虽然服务器没有收到任何消息,但每次推送通知负载都会增加徽章编号。


0
投票

在apns中,有效负载必须定义“content-available”:1表示后台模式下的更新徽章计数

https://developer.apple.com/documentation/usernotifications/unnotificationserviceextension

例如。

-(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {

    application.applicationIconBadgeNumber = 0;
    NSLog(@"userInfo %@",userInfo);

    for (id key in userInfo) {
        NSLog(@"key: %@, value: %@", key, [userInfo objectForKey:key]);
    }

    [application setApplicationIconBadgeNumber:[[[userInfo objectForKey:@"aps"] objectForKey:@"badge"] intValue]];
    NSLog(@"Badge %d",[[[userInfo objectForKey:@"aps"] objectForKey:@"badge"] intValue]);
}
© www.soinside.com 2019 - 2024. All rights reserved.