1.之前产品时消耗性的,直接在 in_app 里边获取 tran_id ,然后做好记录就可以了。
现在产品类型变成订阅类型了。
网上查看实现方式有三种, 1.客户端触发 2.server-to-server 3.定时获取票据的信息,判断上一个支付的情况。
这是一个相关参考 https://juejin.cn/post/7049626884765646884
想问下其中需要注意什么
1
awanganddong OP |
2
awanganddong OP 今天测试的过程中,发现了一个问题。
苹果的内购是以苹果账号为纬度的。也就是一个苹果账号可以与 app 的任意一个账号做关联。 这样就会有一个问题,original_transaction_id 会定位在不同的用户账号上, ios15 增加了这个字段,可以解决这个问题。 https://developer.apple.com/documentation/appstorereceipts/app_store_receipt_data_types 但是我们开发的 ios 13 版本,所以暂时用不到。 所以推送这种方式+定时任务查询票据这种方式我们暂时没有用。 其中定时任务查询票据,就是请求历史票据,获取 latest_receipt ,然后通过 latest_receipt 获取最新的票据信息。 |
3
awanganddong OP 如果是客户端上报票据,这时候就设计到取数据的模式了。
in_app VS latest_receipt_info 根据我个人理解和测试,如果是消耗性小票直接 in_app 模式就可以获取。 如果是订阅型商品,可以取 latest_receipt_info 。 还有一种取法就是获取 latest_receipt ,再次请求苹果 server 。然后去 in_app 取数据,获取到的数据和 latest_receipt_info 是一致的。 |
4
awanganddong OP 记录用户的 transaction_id+original_transaction_id 。
purchase_date_ms/expires_date_ms 这两个字段是判断订阅的开始时间+结束时间。 我这边操作是循环 latest_receipt_info ,然后把上边几个记录保存到数据库,然后给用户加会员时间。 如果已保存,就跳过。 |
5
awanganddong OP 用户的退订问题,现在正在测试。
|
6
awanganddong OP 刚才又实现了新的一版,
思路是这样的。 首先从 lastet_receipt_info 中根据这个字段 purchase_date_ms 倒序, 从中取出最新的一个订单。 然后根据 expires_date_ms 这个字段来更新用户的订阅到期时间。 |