最近出于个人需要折腾了一套微信免签支付的个人系统,下面介绍一下整体的一个实现方案 由于微信本身不提供免签的支付api,因此个人若想要实现免签支付,那么只能通过监听微信收款通知来实现了,因此整个系统的实现部分分为 收款服务端和监听客户端来实现
收款服务端实现
整个收款服务的实现思想是通过app实现对微信通知的监听,当监听到收款信息的时候则把收款金额上报给到服务端,服务端根据收款金额找到活跃订单然后回调支付成功接口,页面实时监测支付状态,当支付成功的时候则跳转成功界面。 具体如图:
那么在这整个流程里面需要注意的就是同时活跃的订单金额是不能重复的
订单创建
从简单点来说订单的创建仅仅是总数据库里面添加一条数据而已,但是在创建订单的时候需要考虑的几个问题
1、避免页面的重复刷新导致订单无限创建 对于用户刷新页面导致的订单一直创建的问题可以使用缓存策略,当发现来源是同一个ip,并且金额相同的时候则会从缓存里面直接获取当前的订单
2、对于重复金额的订单 由于系统是通过金额来确定唯一订单的,那么就意味着同一个商品被不同的用户打开的时候需要生成不同的金额,那么可以采用递增0.01或者递减0.01的策略来实现,不过意味着系统里面需要有更多的同金额的收款码与之对应