项目大致结构:
payorder:订单管理(后台支付订单管理界面)
tra:统计管理(支付统计、提供对账依据)
acc:对账管理(对账、日记)
pay-gateway:支付中心(支付、退款、冲正)
pay-notify:通知中心(银行通知、商户通知)
base-third:对外接口(转发所有对外接口)
支付:
商户端调用pay-gateway相关接口发起支付;
pay-gateway对商户支付订单进行处理,找到对应的支付通道,根据支付通道调用base-third中对应的接口进行支付;
银行(或银联)将支付结果异步通知到pay-notify,pay-notify接收到消息后,将订单信息处理后广播到rabbit;
tra接收到广播后后,判断是否交易成功,将交易成功的订单信息入库;
pay-notify接收到广播后,调用该商户对应的通知地址,将交易订单信息通知到商户;
退款:
商户端调用pay-gateway相关接口发起退款(或后台通过payorder发起退款,payorder调用pay-order的feign发起退款);
pay-gateway对退款订单进行处理,找到对应的支付通道,根据支付通道调用base-third的对应接口进行退款;
银行(或银联)将退款结果同步返回到pay-gateway或异步通知到pay-notify,接收到消息后,将订单信息处理后广播到rabbit;
tra接收到广播后,判断是否退款成功,将退款成功的订单信息入库;
pay-notify接收到广播后,调用该商户对应的通知地址,将退款订单信息通知到商户;
简易对账逻辑:
1、acc配置对账任务;
2、触发对账任务,根据通道交易结算规则,到指定地点下载商户对账单;
3、根据通道交易结算规则,获取该通道该商户的待对账数据(挂销账提前处理,即本地有订单信息,上游通道没有,将账单挂起,下个结算日,上游存在,本地对账单不存在,就去挂起的账单数据中找);
4、将上游对账单与本地对账单都扔到redis里面进行对账。
5、对外后,得到未对平的(上游多平台少),查挂账单,查到销账,未查到,查询本地订单信息,状态不一致,调银行接口查询订单同步状态;
6、将对平的账单生成商户日结数据;
PS:记录备用,简易逻辑,若有错误,欢迎大佬指出。