苹果 iap 自动续费怎么实现

2022-12-24 14:20:16 +08:00
 awanganddong

1.之前产品时消耗性的,直接在 in_app 里边获取 tran_id ,然后做好记录就可以了。

现在产品类型变成订阅类型了。

网上查看实现方式有三种, 1.客户端触发 2.server-to-server 3.定时获取票据的信息,判断上一个支付的情况。

这是一个相关参考 https://juejin.cn/post/7049626884765646884

想问下其中需要注意什么

1283 次点击
所在节点    程序员
6 条回复
awanganddong
2022-12-26 09:55:53 +08:00
awanganddong
2022-12-30 11:56:05 +08:00
今天测试的过程中,发现了一个问题。
苹果的内购是以苹果账号为纬度的。也就是一个苹果账号可以与 app 的任意一个账号做关联。

这样就会有一个问题,original_transaction_id 会定位在不同的用户账号上,
ios15 增加了这个字段,可以解决这个问题。

https://developer.apple.com/documentation/appstorereceipts/app_store_receipt_data_types
但是我们开发的 ios 13 版本,所以暂时用不到。

所以推送这种方式+定时任务查询票据这种方式我们暂时没有用。

其中定时任务查询票据,就是请求历史票据,获取 latest_receipt ,然后通过 latest_receipt 获取最新的票据信息。
awanganddong
2022-12-30 12:00:29 +08:00
如果是客户端上报票据,这时候就设计到取数据的模式了。
in_app VS latest_receipt_info

根据我个人理解和测试,如果是消耗性小票直接 in_app 模式就可以获取。
如果是订阅型商品,可以取 latest_receipt_info 。

还有一种取法就是获取 latest_receipt ,再次请求苹果 server 。然后去 in_app 取数据,获取到的数据和 latest_receipt_info
是一致的。
awanganddong
2022-12-30 12:04:16 +08:00
记录用户的 transaction_id+original_transaction_id 。
purchase_date_ms/expires_date_ms

这两个字段是判断订阅的开始时间+结束时间。

我这边操作是循环 latest_receipt_info ,然后把上边几个记录保存到数据库,然后给用户加会员时间。
如果已保存,就跳过。
awanganddong
2022-12-30 12:05:14 +08:00
用户的退订问题,现在正在测试。
awanganddong
2022-12-30 18:13:08 +08:00
刚才又实现了新的一版,
思路是这样的。
首先从 lastet_receipt_info 中根据这个字段 purchase_date_ms 倒序, 从中取出最新的一个订单。
然后根据 expires_date_ms 这个字段来更新用户的订阅到期时间。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/904441

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX