我正在开发一个使用 Apple IAP 和 StoreKit 框架来购买订阅的客户端/服务器应用程序。
我们希望客户(iPhone 或 iPad)使用 StoreKit 框架通过他们的 iTunes 帐户向苹果进行初始订阅购买,然后将收据传递给我们的服务器,服务器将对其进行验证,然后更新用户帐户状态。我们还希望服务器负责管理订阅状态(检查自动续订、取消等)。这一切都使用 iOS 7 风格的 appleReceipts,而不是目前已弃用的 iOS 6 风格的交易收据。
Apple 的文档说要发布到以下 URL 以验证沙箱中的收据以及收据和密码
https://sandbox.itunes.apple.com/verifyReceipt
到目前为止..一切正常。
让我感到困惑的地方在于响应。苹果的文档说响应应该有多达 4 个字段。如果您正在验证 iOS 7 风格的应用收据,那么您应该只看到前 2 个。如果它是 iOS 6 风格的订阅交易收据,那么您应该看到所有 4 个。
1) 状态(0 表示有效,否则有一些错误代码)
2) 收据(已发送收据的 JSON 表示形式)
3) latest_receipt(仅针对自动续订订阅的 iOS 6 样式交易收据返回。最近续订的 base-64 编码交易收据。)
4)latest_receipt_info(同上JSON格式)
问题 1: 即使我正在验证 iOS 7 风格的应用收据,我也看到了全部 4 个。文档说这不应该发生。
问题 2:
我们希望服务器通过使用客户端在初始购买后传递的原始应用收据轮询此 API 来处理维护用户订阅状态。该latest_receipt_info
字段似乎包含一个不断更新的交易列表,而该receipt
字段是原始的副本,没有更新的交易信息。
我的问题:
似乎服务器可以获取有关更新事务的信息的唯一方法是查看latest_receipt_info
orlatest_receipt
字段,但根据文档,这些字段不应该出现在响应中。
这是 Apple 文档中的错误吗?或者,获取最新交易集的唯一方法是让客户端在收到通知时发送更新的 AppReceipts SKPayementTransactionObserver
?
编辑——根据下面的评论添加所采取的步骤和一些代码。
1) 使用 SKPaymentQueue 购买 autoRenewSubscription 产品:
SKMutablePayment *payment = [SKMutablePayment paymentWithProduct:product];
payment.applicationUsername = [self hashedValueForAccountName:[UserAccount sharedInstance].subscriberKey];
[[SKPaymentQueue defaultQueue] addPayment:payment];
2) 付款完成后,我通过我的 SKPaymentTransactionObserver 收到回电,并通过以下 URL 发送文件:
NSURL *receiptURL = [[NSBundle mainBundle] appStoreReceiptURL];
到我的远程服务器。
3) 我正在使用以下 python 代码来验证收据
import itunesiap
import base64
file = "/path/to/receipt/sandboxReceipt"
f = open(file)
encoded = base64.b64encode(f.read())
with itunesiap.env.current().clone(use_sandbox=True): # additional change for current environment.
response = itunesiap.verify(encoded,"mysecretkey")
响应包含字典。字典有以下字段
"latest_receipt" = base64 encoded receipt here
"latest_receipt_info" = a JSON representation of the latest receipt
"receipt" = a JSON representation fo the receipt I sent for verification
文档说前两个字段是
“仅针对自动更新订阅的 iOS 6 样式交易收据返回。”
- 为什么他们会出现在这里,因为我正在验证 iOS 7 风格的应用收据?
- 如果这些字段不应该存在,我如何获得最新的交易信息?