支付渠道参数如何设计成路由化配置

转载自  支付渠道参数如何设计成路由化配置

今天我们来探讨在搭建支付系统时一个比较关键的问题:渠道参数路由化配置如何设计?

在开发支付系统的时候,我们经常会涉及到对接多个支付渠道,除常见的支付宝、微信外可能还会根据不同的业务场景对接很多其他的支付渠道,如apple pay、银联甚至一些海外支付渠道如Adyen、Stripe等。

此外,根据公司业务类型的扩展,以及业务范围不断向不同国家、区域的延伸,面临法律、税收、区域产业政策等不同因素的影响,同一个支付渠道也会根据业务类型、国家、区域等因素的不同而申请不同的支付商户号以关联不同的法律主体。

这些问题在公司发展的早期,业务比较简单的情况下一般是不会遇见,但是一旦随着公司业务的快速发展这些问题就会逐步显现出来,而大多数创业公司在早期开发支付系统的时候是很少考虑这些问题的,一方面是时间成本问题,另外一方面也是初创公司真正拥有支付系统研发经验的工程师比较稀缺,而前期的考虑不足往往也会造成后期支付系统在支撑业务快速发展的过程中显得举步维艰,维护成本及业务适配复杂度变得十分高昂。

 

那么上述情况会究竟造成什么样的问题呢?

从上图杂乱的关系图中可以看到,不同的业务线拥有不同的业务,不同的业务及业务线在又拥有不同的支付方式以及不同的支付渠道商户号,如果业务涉及海外,还会根据不同的国家在具体支付方式选择上有不同的要求及规则。

而这样的场景也并不是从公司初创开始就这么复杂,而是随着业务发展日积月累产生的,在早期构建支付系统的时候如果不加以考虑,随着业务的快速发展系统就会始终处于一个被动改造的境地,最终代码中充斥着各种个性化逻辑场景,导致维护成本高昂且极容易出错导致线上Bug,并且也会导致支付数据纬度混乱,影响对账、清结算等其他系统逻辑。

那么怎么设计才能让渠道管理更加具有扩展性呢?

 

业务模型的定义

根据上述因素,我们可以进行下抽象,具体来说各业务线对于支付平台来说可以理解为商户(Merchant),在对接支付系统的时候可以为不同的Merchant开通不同的支付商户ID及接口对接参数;同一个业务线也会有不同的业务,而业务可能比较独立也可能会与其其他业务存在交叉关系,为了更好的厘清关系,我们对同一个商户下的不同业务设计成两个维度:应用(App)、业务类型(BusiType)。

另外比较关键的概念就是渠道(Channel)可以为对接的不同支付渠道定义Channel编码进行区分,根据渠道合作方式的不同,有些海外渠道也会存在子渠道(SubChannel)的情况,这种情况一般是主渠道提供技术接口,而具体不同的子渠道直接对Merchant进行资金清结算。

不同的渠道也会根据收单场景及不同的交易类型(TradeType),如支付、退款、转账、红包等提供不同的支付方式(PayMethod),这些支付方式在国内的情况主要是支付公司根据市场情况的不同而定义的特定支付产品,例如“支付宝App支付”针对移动端App应用的支付场景,“微信小程序支付”针对微信小程序应用的支付场景。

而海外支付渠道则可能会根据不同国家的业务发展情况而定,例如Adyen在香港具备本地收单资质,那么如果希望通过Adyen在香港开展业务,除了可以通过Visa/Master收单外,也可以对接Adyen的ideal(本地化收单)方式。

这里的情况不同渠道表现方式会有所不同,但从我们搭建支付系统的角度看,都可以统一定义为支付方式(PayMethod)。

采用上述几个概念设计渠道参数配置规则,基本上就能确保支付系统在后续的发展过程中向上能够优雅地适配业务发展的不同要求,向下可以从容扩展不同的渠道了。并且通过这些定义可以有效地区分支付数据的维度,使得后续的对账清结算处理更加便捷。

考虑到海外情况及渠道接口版本升级问题,可以再加上国家(Country)、接口版本(Version)两个要素。

 

配置模型设计

通过上述业务模型的定义,在系统实现时我们需要设计一套配置表,并在渠道对接编码时按照配置逻辑进行接口参数路由动作,从而让系统具备渠道管理的配置能力。

基于上述配置模型,我们就可以在业务与渠道参数配置上实现相对灵活的配置与路由了。假设,如果我们在完成微信渠道支付接口的对接并满足了业务A的支付需求,如果业务B也需要采用微信进行支付,并且申请的是独立于业务线A的支付商户信息,那么此时我们只需要完成渠道参数配置表的配置,并且在开通业务线B商户ID及应用ID后进行路由规则设置,系统即可完成支持,而不需要进行硬编码的改造。

 

安全风险及其他

采用配置化方案设计,可以让支付系统更好地适配后期业务发展带来的复杂性,但是我们也需要考虑到操作风险,根据以往经验,不受控的便捷往往会带来危险,试想下如果因为配置错误,原本应该收到B账户的钱,被收到了A账户,而这两个账户主体完全不同,这种情况不仅会导致资金问题、也会影响支付系统后面的逻辑,例如退款问题等。所以,我们在采用这样方案的同时,也需要制定严格的操作规程,在配置系统上设计更为严格的审查流程。

此外,渠道参数属于敏感信息,在配置上也需要采取必要数据安全措施(如加密),另外,因为这类参数是属于低频变更、高频使用的配置数据为了系统效率我们往往也采用缓存机制,做好缓存与持久层数据的一致性及缓存数据的安全性也至关重要。

 

后记

在支付系统设计的早期,如果我们能适度的对配置化模型加以考虑,虽然,会在一定程度上增加研发成本,但随着业务发展,这种成本相较于后期对业务适配改造的成本来说,则是可以忽略的。因为,支付系统对于任何互联网公司来说,都是很关键的业务系统,并且一旦上线就处在了高速运转的模式之下,开着车更换轮子的成本往往比造一辆车的成本更高。

并且,从一些公司的实际情况来看,很多都是在处于无法维护或维护成本异常高昂的情况下,重新花费了很大的精力及成本重建了支付系统。做好支付系统涉及很多细节,这里只是介绍了其中一个比较关键的细节内容,希望能对大家有用~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325825.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实现Windows程序的数据更新

一、枚举: 1.语法:public enum 名字{ 值1,值2} 2.eg:public enum Genders{Male,FeMale} 3.使用枚举:枚举名.值 4.枚举的好处: (1)使代码更易于维护 (2)更易于用户输入值,直接用.的方式就可以获取值 (3)使代码更清晰&a…

分布式数据访问服务之1—华山论剑篇

业界主流的互联网架构中,分布式服务框架、分布式数据访问服务、消息队列服务、服务网关(API)、分布式事务等都是核心的组件和框架。 当我们的系统规模越来越大,从几台服务器扩展到几十台、几百台、上千台,传统的烟囱式的、大集中式系统架构&…

Android中异步任务AsyncTask的使用

1、当程序启动的时候,Android同时会启动一个对应的线程,【主线程、UI线程】主要负责处理与UI相关的线程 2、UI线程不允许访问网络进行耗时操作 3、子线程不允许更新UI。 由于Android中主线程不能访问网络、子线程不能更新UI,需要线程间通讯 完…

漫画:什么是快速排序?(完整版)

转载自 漫画:什么是快速排序?(完整版) 同冒泡排序一样,快速排序也属于交换排序,通过元素之间的比较和交换位置来达到排序的目的。 不同的是,冒泡排序在每一轮只把一个元素冒泡到数列的一端&a…

测试——《微服务设计》读书笔记

一.测试象限(Brain Marick) 二.测试金字塔(Mike Cohn) 1.单元测试 通常只测试一个函数或方法调用,通过TDD或者基于属性而写的测试就属于这一类,在UnitTest中,我们不会启动服务,对且对…

React功能界面的组件化编码流程

功能界面的组件化编码流程(通用) 1.拆分组件: 拆分界面,抽取组件 2.实现静态组件: 使用组件实现静态页面效果 3.实现动态组件 3.1 动态显示初始化数据 3.1.1 数据类型 3.1.2 数据名称 3.1.2 保存在哪个组件? 3.2 交互(从绑定事件监听开始)

Java 多文件上传

转载自 Java 多文件上传 前台代码很简单&#xff1a; <input type"file" accept".zip" class"file-load" multiple"multiple" name"files"/> 后台代码&#xff1a; public boolean uploadFlow(RequestParam Mult…

MyKtv点歌系统前台主要功能实现,内附数据库脚本,可以直接运行

C#开发工具&#xff1a;Visual Studio 2012 数据库&#xff1a;Sql Server Windows版本&#xff1a;Win10 分辨率&#xff1a;1366*768 文章的最后有KTV点歌系统的前后台源码下载链接。 在正式写代码之前先看一下运行效果图&#xff0c;如果觉得这个是你需要的&#xff0c;那么…

Hibernate使用最新的MySQL8.+版本出现的问题!

目前所出现的问题 1、驱动包更新为 mysql-connector-java-8.0.12.jar 2、hibernate的配置文件hibernate.cfg.xml中使用 <property name"connection.driver_class">com.mysql.cj.jdbc.Driver</property>取代之前的 <property name"connection.d…

支持断线重连、永久watcher、递归操作 ZooKeeper 客户端

项目介绍 ZooKeeper本质上是一个分布式的小文件存储系统。原本是Apache Hadoop的一个组件&#xff0c;现在被拆分为一个Hadoop的独立子项目。 Zookeeper 作为一个分布式的服务框架&#xff0c;主要用来解决分布式集群中应用系统的一致性问题&#xff0c;它能提供基于类似于文…

mongdb总结

#清屏 cls --windows #操作数据库 show dbs --查看所有数据库 use dbName --使用已有的dbName数据库&#xff0c;或者创建新的数据库dbName&#xff0c;如果一个数据库没有表就不存在 db --显示数据库名称 #操作集合 show collections …

JavaScript操作BOM简单案例

需要两个页面index.html和Test.html&#xff0c;可以直接运行&#xff0c;每个功能都已经注释完整&#xff0c;index.html页面的代码&#xff1a; <!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title></head…

Java中“/”,“.”所代表的文件路径

转载自 Java中“/”&#xff0c;“.”所代表的文件路径 我们在开发的过程中&#xff0c;经常会去读、写文件。在读写文件的时候&#xff0c;就不得不写文件的路径&#xff0c;使用相对路径的方式有两种&#xff1a;”/”和 “.” 。在写文件的路径的时候&#xff0c;需要了解一…

Hibernate框架(1)

1.Hibernate框架简述 Hibernate的核心组件 在基于MVC设计模式的JAVA WEB应用中&#xff0c;Hibernate可以作为模型层/数据访问层。它通过配置文件(hibernate.properties或hibernate.cfg.xml)和映射文件(***.hbm.xml)把JAVA对象或PO(Persistent Object,持久化对象)映射到数据库中…

通过 Transifex 中文化开源软件

如果您对于汉化软件充满热情, 我软已经发布了以下的开源产品在 Transifex 平台&#xff0c;让社区的小伙伴们参与翻译以及审核: 如何参与? – Transifex 的新手 登录 Transifex 如果您第一次使用 Transifex, 您可以新建立一个账号或是通过您的 GitHub, Google 或 LinkedIn 账号…

JavaScript操作DOM元素

一、DOM&#xff1a; Document Object Model&#xff08;文档对象模型&#xff09; 二、DOM的分类&#xff1a; 1.DOM Core&#xff08;核心&#xff09; 2.HTML-DOM 3.CSS-DOM 三、节点属性&#xff1a; 1.lastElementChild:最后一个节点 2.firstElementChild:第一个节点 3.ne…

hibernate的lazy的使用

引用&#xff1a;https://blog.csdn.net/Vincent_yuan1991/article/details/53482487 一&#xff1a; lazy&#xff0c;延迟加载 Lazy的有效期&#xff1a;只有在session打开的时候才有效&#xff1b;session关闭后lazy就没效了。 lazy策略可以用在&#xff1a; 标签上&#x…