5

当您的 iPhone 收到 WhatsApp/Telegram 推送通知时,例如

wife:
"buy pizza"

问题1:应用程序是否必须自行下载/接收。那就是手机上弹出的横幅必须自己下载+我的Whatsapp / Telegram必须自己再次下载?

我的朋友回复:

推送通知可以将消息作为有效负载。您的应用程序可以提取它并动态插入对话,而无需发出额外的请求——我以前做过。让人感觉快了很多。不利的一面是,您不能保证推送会以正确的顺序(或根本没有)到达。

但我不相信,从语义的角度来看,推送通知不应该真正更新您的应用程序本身。如果他们这样做,那将是一种滥用......他们应该只通知您的应用程序有更新,然后允许您通过下载任何可用的新内容自己进行更新。

因此,为了看看顶级公司和他们的应用程序是否在应用我朋友的建议,我对 3 个应用程序(Gmail、WhatsApp、Telegram)做了一个小实验:

我关闭了 Wifi,但保持蜂窝数据打开,然后我还禁用了应用程序使用蜂窝数据的访问权限。

在此处输入图像描述

然后我有人给我发了一条消息/电子邮件:这是我的结果:

电报::我收到一个警报(有发件人+第一行)。但是一旦我打开应用程序(或点击通知),它就没有我的新消息或任何东西。

但是,如果允许 Telegram 访问互联网……它会在后台下载消息……也就是说,如果我遵循以下顺序:我是 wifi 或没有互联网限制的蜂窝数据 --> 收到通知 --> 转互联网完全关闭,然后转到应用程序:我会在那里看到完整的消息/正文。

Gmail:我收到一条警报(有主题/发件人/正文的预览)但是一旦我打开应用程序,它就没有我的新消息或任何东西。

如果允许 Gmail 应用程序访问互联网……那么与 Telegram 相反:只有在打开应用程序本身之前,它才会下载/更新 Gmail 中的电子邮件。我猜 Gmail 没有content-available设置为,1但 Telegram 已设置为1

WhatsApp:我什么也没得到。

收到通知后不会发生任何交互......只有当应用程序正在下载自己时才会发生。

我的结论是:

收到通知后不会发生任何交互......只有当应用程序独立于有效负载到达时下载自己时才会发生。

Gmail 和 Telegram 正在进行冗余下载,基本上对我朋友的建议不够聪明,或者没有收到电子邮件/消息的风险太大,最好是安全的:thinking_face:

问题2:这个结论正确吗?

4

1 回答 1

4

首先,下载有效载荷通常不是问题。我想有效负载通常非常小(短文本消息可能<1Kb)。事实上,常规远程有效负载的最大大小为 4KB(VoIP 通知为 5KB)。请参阅创建远程通知负载

其次,您的应用程序很难访问任何远程通知数据。唯一可行的方法是通过静默通知,不建议将其用于简单的文本通知。静默通知会唤醒您的应用程序并给它 30 秒的时间在后台执行操作,然后再再次关闭。您可能会发送远程静默通知,导致您的应用手动触发基于该远程通知的常规本地通知(或同时发送静默和常规远程通知),但同样,不建议使用静默通知:

静默通知并不是为了让您的应用在后台保持清醒,也不是为了高优先级更新。APNs 将静默通知视为低优先级,如果总数过多,可能会完全限制其传递。实际限制是动态的,可以根据条件更改,但尽量不要每小时发送超过几个通知。

有关详细信息,请参阅配置静默通知

修改远程通知的有效负载中描述了应用程序可以在收到远程通知时“下载”远程通知的另一种可能方式。您可以简单地保存通知并选择不修改它们。

对于您的任何一个问题,都没有适用于所有应用程序的通用是/否答案。相反,应用程序可以通过多种不同的方式接收远程通知并处理其数据。

编辑:您还应该application(_:didReceiveRemoteNotification:fetchCompletionHandler:)从通知的用户信息中实现和检索/保存数据,以便数据在您的应用程序中更快地可用。但是,不能保证调用该方法。所以你可以/应该实现它,但更重要的是,让你的应用程序检查来自你自己服务器的新数据,这样就不会遗漏任何东西。

于 2017-06-15T20:02:49.190 回答