我对验证订阅我的应用的用户的收据所涉及的过程有点困惑。
在用户加入并购买订阅的那一刻,收据会被 base64 编码并发送到我的服务器。每晚午夜,服务器会将存储在我的数据库中的收据发送给 Apple 以进行验证并更新到期日期。
现在我对每个月如何更新收据有点困惑。请查看以下流程,如果正确,请告诉我。
- 用户注册并订阅了我的应用。(假设是一月)。
- 原始收据被发送到我的服务器,然后通过 Apple 验证,到期日期返回并在我的服务器上设置。
- 一个月后的 2 月到期日,我再次将原始(1 月)收据发送给 Apple,以查看订阅是否已续订,然后我可以设置新的到期日。
这个流程正确吗?因为我每个月都会发送原始(1 月)收据,它是否仍会包含最新的续订信息,或者我是否必须每月在用户登录或打开应用程序时刷新收据?
Best Answer-推荐答案 strong>
是的,您的理解或多或少是正确的。当用户第一次续订时,会发生几件事:
下次用户启动应用时,您的 SKPaymentQueue 委托(delegate)将收到新交易的新 SKPaymentTransaction 。您需要准备好与您的委托(delegate)观察此事务并完成它。如果你不这样做,交易将在几个月内继续堆积。
从 Apple 收到的第一个收据的 verifyReceipt 响应将更新 latest_receipt_info 键以包含最新版本的收据数据。 latest_receipt_info 最初只是 receipt.in_app 字段的副本,但在第一次续订后,它将包含最新的交易。您应该使用这些 latest_receipt_info 交易来更新到期日期。
我建议的行为是,当您收到新的 SKPaymentTransaction 时,无论如何您都将其发送到您的服务器(尽管您在技术上不需要),然后您使用它来验证和更新到期日期之前完成交易。您可以用新收据覆盖旧收据。
您可以查看 RevenueCat iOS framework source code看看我如何处理它。 (如果收据数据丢失,您还应该确保触发获取收据请求,我在代码中这样做。)
如果您对开箱即用的解决方案感兴趣,RevenueCat是一项服务,我开始自动处理所有这些以及更多的边缘情况。
关于ios - Apple Auto Renewable Subscriptions - 根据收据验证用户,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/47228274/
|