在 iOS SDK 中识别用户

Adapty 会为每位用户创建一个内部用户画像 ID。不过,如果你有自己的认证系统,建议设置你自己的 Customer User ID。你可以在用户画像部分通过 Customer User ID 查找用户,也可以在服务端 API 中使用它,该 ID 会同步发送到所有集成渠道。

在配置时设置客户用户 ID

如果在配置阶段已有用户 ID,只需将其作为 customerUserId 参数传入 .activate() 方法:

想了解 Adapty SDK 如何集成到移动应用中的真实示例?请查看我们的示例应用,其中展示了完整的配置过程,包括显示付费墙、完成购买以及其他基本功能。

配置完成后设置客户用户 ID

如果在 SDK 配置时没有用户 ID,可以随时通过 .identify() 方法来设置。最常见的使用场景是在注册或登录之后,即用户从匿名状态切换为已认证状态时。

请求参数:

  • Customer User ID(必填):字符串类型的用户标识符。

重新提交重要用户数据 在某些情况下,例如用户再次登录账户时,Adapty 服务器上已经存有该用户的信息。此时,Adapty SDK 会自动切换到新用户。如果你之前向匿名用户传递了任何数据(例如自定义属性或来自第三方网络的归因信息),则需要为已识别的用户重新提交这些数据。

另外需要注意,识别用户后应重新请求所有付费墙和产品,因为新用户的数据可能有所不同。

登出与登录

您可以随时调用 .logout() 方法使用户登出:

之后,您可以使用 .identify() 方法让用户登录。

设置 appAccountToken

appAccountToken 是一个 UUID,帮助 Apple 的 StoreKit 2 跨应用安装和设备识别用户。

从 Adapty iOS SDK 3.10.2 开始,您可以在配置 SDK 或识别用户时传入 appAccountToken

之后,您可以使用 .identify() 方法登录用户。

跨设备识别用户

当 SDK 激活时,它会自动从 StoreKit (iOS) 或 Google Play Billing (Android) 读取用户现有的权益,并将其同步到 Adapty 后端。活跃订阅无需应用调用 restorePurchases,即可出现在 Adapty 用户画像中。

不会自动发生的是:识别新设备上的用户画像与原设备上的用户画像属于同一用户。Adapty 通过 Customer User ID 匹配用户画像,因此身份连续性取决于您使用什么作为 CUID。

Adapty 跨设备可检测的内容

您的配置Adapty 检测到的内容您需要做什么
Customer User ID = device_id(无应用登录)新设备获得不同的 CUID,因此拥有不同的用户画像。订阅通过 Access level updated 事件同步到新用户画像,但 subscription_started 不会触发——新用户画像被视为原始购买的继承者。基于 subscription_started 的分析将少计回归用户。使用稳定的账户 ID 作为 Customer User ID,以便回归用户能跨设备匹配到现有用户画像。
Customer User ID = 稳定账户 ID(每台设备均需登录)SDK 在 activate() 时自动同步订阅,identify() 通过 CUID 匹配现有用户画像。无需额外配置——身份和订阅均可自动解析。
Apple Family Sharing 继承者家庭成员仅通过 Access level updated 事件接收订阅——subscription_started 不会触发。监听 Access level updated。完整的事件矩阵请参见 Apple Family Sharing
同一 Apple/Google 账户,不同应用内用户最先记录购买的用户画像成为父级。后续用户画像通过继承链查看订阅,并触发一次 Access level updated 事件。要求用户登录,然后选择适合您业务模型的共享模式

在新设备上恢复购买

在付费墙上提供一个用户可主动触发的”恢复购买”按钮。Apple App Review(指南 3.1.1)要求提供此按钮,且当自动同步遗漏边缘情况时,它也可作为备用方案。该按钮应调用 SDK 中的 restorePurchases

正常使用时,首次启动时无需通过代码调用 restorePurchases——SDK 已在 activate() 时执行了等效操作。仅在需要强制刷新收据检查时才使用代码调用,例如在 activate() 完成后调试访问等级缺失问题时。