当我的服务用户注销我的应用程序时,如何可靠地使设备的推送令牌无效(从我服务器上的用户配置文件中删除)?
我在我的用户配置文件中保留了一组包含 apns 令牌的字符串,每当用户在给定设备上启用推送通知时都会添加一个。
后来我意识到推送令牌对于设备来说是唯一的,但显然对我的内部用户帐户一无所知,所以如果一个用户注销并且另一个用户登录(同一设备),他们每个人都有相同的令牌。然后设备的当前用户会收到针对其中任何一个的推送通知。
基本的解决方案是在注销时从用户配置文件中删除设备的令牌,但我想出了一堆问题,因为我认为是这样的:
- 注销不需要网络访问——我可以尝试通知我的服务器,但即使用户没有网络访问权限(?)也需要异步注销才能成功
- 实际的设备令牌可能是未知的——如果用户暂时关闭了推送权限,则不会给出当前令牌。并且存储设备<->密钥信息似乎充其量是微不足道的,因为每次安装的 identifierForVendor 更改和 UDID 方法已被弃用。
- 做服务器端唯一(在向帐户添加令牌时,确保没有为任何其他帐户设置相同的令牌)——这取决于第二个用户登录,这不能保证。
是否还有更多我遗漏的边缘案例以及我可以使用哪些策略来解决它们?