5

我目前正在研究一个支持在线离线的应用程序并弄清楚APNS的用法,当我的应用程序只处理单个用户时很容易理解。(就像短信一样)

我的理解是,安装到特定设备的每个应用程序都会有自己的设备令牌(即使在取消注册到 APNS 并重新注册后也不会更改)。因此,当用户从不同的设备登录时,APNS 进而服务器可以识别。

但是,当我尝试实现多帐户应用程序(就像 Facebook,不同的人可以使用同一部手机登录)时,出现了一些问题。

当用户 A 登录并且应用程序处于后台状态时,是的,它确实收到了通知。

但是当用户A退出时(当手机没有互联网连接时,这意味着无法立即更新服务器以删除帐户),然后用户B登录,同时服务器试图向用户推送通知到手机A,电话已经收到通知(但这是用户 A 的通知),用户 B 会收到通知(这在实际场景中永远不会发生)。

似乎 APNS 无法检查应用程序帐户身份验证。

所以,我的问题是,

  1. 有什么方法可以检查和删除手机上的通知(我已经阅读了 Apple Doc。并注意到有一个 QoS 存储了最后一个通知)?

  2. 在使用 APNS 时处理此类身份验证问题的良好做法是什么?

如果我确实有任何概念上的误解,请纠正我。并希望我的问题听起来不愚蠢和笨拙,并且没有任何问题重复......

4

2 回答 2

3

如果您具有从您的应用程序“注销”的功能(无需登录新用户),我找不到任何方法来停止发送推送通知,除非让服务器知道用户已注销。

如果没有互联网连接,则无法正确注销。如果您需要此功能,您应该验证与服务器的注销。可以通知用户注销失败,因为无法访问服务器。

这是一个例子:

  • 用户 A 登录具有设备令牌 TX 的设备 X。

    -> 服务器将令牌 TX 关联到属于用户 A。

  • 用户 A 在设备 Y 上登录,该设备具有设备令牌 TY。

    -> 服务器将令牌 TX 和 TY 关联到属于用户 A。

  • 推送给用户 A 的消息

    -> 服务器向 TX 和 TY 发送推送消息。

  • 用户 A 从设备 X 上注销,用户 B 在设备 X 上登录。

    -> 服务器删除令牌 TX 与用户 A 的关联

    -> 服务器将令牌 TX 关联到用户 B。

  • 推送给用户 A 的消息

    -> 服务器向 TY 发送推送消息。

  • 推送给用户 B 的消息

    -> 服务器向 TX 发送推送消息。

  • 用户 B 退出,但没有互联网连接

    -> 登录失败,用户 B 仍然登录,收到对话框“无法注销”

于 2012-08-02T10:29:03.457 回答
2

所以,一开始:

用户 A 如何在没有互联网的情况下注销并登录 Facebook?

当用户 B 登录时,因此互联网已连接,然后您可以发送到您的服务器:现在用户 B 在此设备令牌上。

例如:用户 B 登录,同时服务器尝试将通知推送到用户 A 的手机

如果应用程序已运行,则您将收到 APNS 通知

application: (UIApplication*)app didRegisterForRemoteNotificationsWithDeviceToken: (NSData*)deviceToken

不在设备通知中心消息窗口中。

你可以这样做:

1)如果用户A已经登录,则发送本地通知以显示通知

2)如果log中的其他用户或用户被注销,那么什么都不做

希望它有所帮助。也许我错了,如果你的意思是另一个。

于 2012-08-02T09:51:48.370 回答