其实想跟大家分享这套支付系统的架构已经很久了,今天总算有时间写出来了。
先说说这套系统的需求由来吧:
- 笔者公司的游戏产品已经有几款了,每次上各种渠道都是要搭配不同的计费方式,并且每开发游戏都要重复一遍痛苦的接入sdk流程
- 游戏的支付需要出各种报表以及统计,每个游戏单独去做对人力的消耗巨大
基于以上几点,我这边设计了统一支付系统。
这个系列一共会分两篇文章,分别对应系统的v1版和v2版,我们这一篇先从v1起介绍。
在仔细分析了国内的大多数支付sdk之后,我们梳理出游戏的支付流程大体可以实现为两类:
- 第三方sdk服务器进行支付结果通知
- 第三方sdk客户端直接返回支付结果通知,没有服务器支付结果通知。
对于调用方而言,这两种方式各有好处。
- 第一种方式更加安全,但是支付调用的时间相对较长
- 第二种方式速度更快,但是很容易被不怀好意的人破解。参见之前的文章:google支付接口被刷以及解决方案
接下来,我们来看一下我这边设计的统一支付流程。
客户端:
服务器端:
简单解释一下:
- 每次支付开始,都要让服务器生成一个订单作为此次支付的记录,订单的id即为 bill_id。订单有4中状态:订单生成,支付失败,支付成功,发货成功。
- pay_server即为统一支付系统的服务器端,考虑到调用量和方便调试,使用了简单的http协议+json+sign的方式
对于服务器内部,唯一麻烦的一点是,《等待pay_server支付结果通知》这个接口。因为这个http请求需要支持挂起,在第三方支付服务器通知了pay_server之后,pay_server 根据通知里面透传的bill_id 将订单状态修改后,再给客户端结果 ...