遇到的问题
Google 订阅在未过期之前,用户取消订阅,然后在我们app内购买订阅,Google 会产生一笔费用为0的订单,其实也就是说这个时候应该是不扣款,也不发会员。
正常的回调流程
谷歌扣款成功-->发送消息到回调地址-->验证回调信息的正确性-->查询google订单信息-->订单记录订单并发放会员
之前的设计是:只要查询的谷歌订单有效就会发放会员,用户取消订阅后再从app内购买订阅 就会生成一个新的订单而且认为是有效订单(其实这个订单是0元单)(如果用户在会员未到期之前一直操作取消订阅再重新app内购买订阅, 就会一直薅...)
场景:
假如用户A新订阅一个商品A产生的订单编号GPA.1234567(订单1),支付成功之后会员到账了,用户A取消订阅,再去app重新购买商品A,支付的金额实际为0,谷歌回调的订单编号是GPA.4567890(订单2),按照上边的逻辑只要验证(订单2)是支付成功的就直接给用户A会员到账了
解决思路
(主要的解决思路来源阅于:https://juejin.cn/post/7202211586675687483)
订单回调时会返回一个 purchaseToken 和 linkedPurchaseToken 通过这两个字段去验证两笔订单是否有关联,下