[分享摘要]支付中心设计与实践

收集金币的马里奥

演示 DEMO:扫码支付

支付“不难做”:App 支付,一名 iOS 工程师唰唰唰搞定;微信 JS 支付,一名前端工程师唰唰唰搞定。而如果想做一个通用可扩展的支付系统,90% 的工作在后端,做起来也并不是很容易。

背景

  • 早期业务A已引入支付宝支付
    • 发起支付逻辑在客户端,支付单号业务关联性强不通用(客户端写死逻辑影响后端重构一坑此处不表)
    • 支付网关回调接口在 API 项目中,API 项目异常会引起支付问题(客户端一脸萌比)
    • 测试支付?先把业务逻辑走一遍
  • 业务 B 有单独的网页端扫码支付,跟客户端没什么关系……
  • 后来业务C需要引入支付宝
    • 原有逻辑无法重用,依旧是写一套新的,对应业务逻辑依旧耦合
    • 对客户端来说,API 也是两套
    • 后端支付网关回调也是两套
  • 产品说要加微信支付……😢
  • 后来说要有更多业务、商品需要支付……😢😢😢

一次支付背后发生的故事

支付宝支付简化模型:

最简支付模型.png
  • 最简,如果是微信支付需要预下单
  • 最简单支付除了必备价格,其它并不重要
  • 支付发起在客户端,看似没问题,但是没扩展性
  • 客户端发起最大的问题是成单逻辑在客户端,不可控:难以追踪统计,不可变更

Review 需求:

  • 工程师角度:扩展?(我只是不想写重复代码,改来改去)
    • 新增业务支付、商品支付,支付中心、客户端及前端不需要动代码
    • 新增支付渠道,业务不需要动代码,支付相关不需要动老代码
    • 支付中心自洽,模块职能清晰,有日志,可追溯分析
    • 易测试
  • 产品运营角度:
    • 上新商品支付,快
    • 支持优惠券
    • 灵活,多端支付,自定义价格支付,发个消息支付……
    • 数据完善
    • 有没有更多可能?
  • 公司角度:安全
  • 注:以上皆为完成后臆测 ;)

一次“复杂的”支付背后发生的故事

支付中心业务时序图.png

划重点

  • 定义支付中心(PayCenterServer & 客户端 & 前端):
    • 封装支付逻辑,与终端&支付网关直接对接,对业务方透明
    • 对外方便对接多个业务方
    • 对内方便扩展终端,扩展支付网关
  • 业务方拿到 PayOrderId,其它的支付过程都交给终端,坐等 PayCenterServer 的 bizNotifyUrl 通知(有模仿的重复通知逻辑)
  • 支付中心需要理解的外部概念: bizOrderId, bizNotifyUrl, (couponId, goodsId, unionOrderId)
  • 内部数据只有两类:PayOrder, GatewayOrder
  • 易测试

聊聊一些坑

  • 微信开放平台(open)和公众号平台(mp)是不同的 appId,支付字段也略有区别
  • 多钟支付类型的字段解析归纳,是局部实现的难点:
    • 每种支付渠道都不同,同种支付渠道扫码、H5、App 也不完全相同
    • 签名阶段、终端展示、验签阶段
    • DEMO:各终端需要的不同字段
      • 微信为例:JS,扫码,APP
  • 签名、验签逻辑理解
    • 银联证书的坑
  • TRADE_FINISHED,迟来三个月的 bug

后续

  • 优惠券
  • 商品中心
  • 订单中心

总结

  • 区分变化很重要
    • 前期很容易因为支付流程是复杂的,签名是复杂的,错误认为这是变化部分。支付流程梳理清楚后这部分反而是稳定的
    • 支付流程、签名是固定的,不变的,而且是内部的
    • 与业务端,终端以及支付网关后台的交互是设计重点
  • 测试优先(线上也要易测试)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容