分销电商结算设计

概述

分销电商中涉及支付与结算;支付职责是收钱,结算则是出钱给各利益方

结算核心围绕业务模式涉及哪些费用,以及这些费用什么时候通过什么出资渠道,给到收方利益方

结算要素组成=费用项+结算周期+出资渠道+出方&收方;整体设计也是围绕这4大要素进行设计;

涉众分析

用例

模型

从命令事件中分析出有合同,费用项,计费单,结算单实体;

领域模型

收单单据:面向交易域:接收确认收货消息以便后续的结算处理;保证后续有据可依;

计费单:交易单对应费用项具体计费结果及中间计算过程存储;计费单是最细的费用明细,如酒店业务平台抽佣包含了服务费及平台费,这个财务视角需要关注;

清算单据:定义商家视角下后续结算给利益方的费用项;多个计费单可合成一个清算单,如酒店业务服务费及平台费合成平台抽佣;如平台模式下有:平台抽佣及商家货款;核心包含费用项及金额;

结算单据:记载某个费用项&结算双方&什么周期进行结算;结算单是对于费用项增加结算出资及收入方以及周期结算的叠加信息;

打款单:实际处理结算单据最终以什么出资渠道工具进行出资;

结算合约:定义商家什么时间点签证了结算合同及合同有效期

结算条款:定义费用项&商家&收付结算账号&以什么周期结算条款;条款挂在合约下

费用项定义某个业务的业务模式下具体费用类型计算方法;这个是业务下固定的费用项,由运营设置;如电商电器业务的平台模式下,业务运营设置平台抽佣费用项,计算方法是交易金额*佣金比率;

费用项因子:记录费用项涉及计算因子;如平台抽佣=结算基数*佣金比率,这里的结算基数及佣金比率就是因子;

费用项实例:定义某个商家对应合同上定义的费用项具体实现费率;费用项实例明细则用于承载阶段费用模式下具体费用明细;

模型推演

  • 电器平台抽佣

        运营定义费用项:平台抽佣及商家货款;平台抽佣=结算基数*佣金比例;商家货款=结算基数-平台抽佣;

        定义费用项因子:结算基数因子,具体这里可以写插件服务地址;佣金比例也可以填写插件地址;平台抽佣写计费抽件地址;

        商家入驻

                1、生成结算合约记录:内容是商家id&生效开始及结束时间&状态;

                2、生成结算合约条款记录:内容是对应费用项实例及费用项明细;

                        费用项实例包含:费用类型为平台抽佣,费用计算类型为固定比例,计算表达式:结算基数*佣金比例,条件表达式:渠道=*(即全部渠道);

                        费用项实例明细包含:计算表达式值:结算基数*0.9;条件表达式值:渠道=*(即全部渠道);

  • 电器阶梯平台抽佣

            运营定义费用项:平台抽佣及商家货款;平台抽佣=结算基数*佣金比例,计费方式为阶梯计费;商家货款=结算基数-平台抽佣;

            定义费用项因子:结算基数因子,具体这里可以写插件服务地址;佣金比例也可以填写插件地址;平台抽佣写计费抽件地址;商家交易GMV因子:写计费实现地址;

            商家入驻

                    1、生成结算合约记录:内容是商家id&生效开始及结束时间&状态;

                    2、生成结算合约条款记录:内容是对应费用项实例及费用项明细;

                            费用项实例包含:费用类型为平台抽佣,计费方式为阶梯比例,计算表达式:结算基数*佣金比例,条件表达式:渠道=*(即全部渠道);

                            费用项实例明细阶梯1:计算表达式值:结算基数*0.9;条件表达式值:渠道=*(即全部渠道) and 商家交易GMV>=0 and 商家交易GMV<100000;

                            费用项实例明细阶梯2: 计算表达式值:结算基数*1.5;条件表达式值:渠道=*(即全部渠道) and 商家交易GMV>=100000 and 商家交易GMV;

逻辑架构

领域划分:收单域,计费域,清算域,结算域,财务域及合约域;

收单域职责:与业务方交互接收业务结算事件,核心记录结算事件后期有据可依;

计费域:管理结算费用项&提供费用项计费能力;每个业务独立定义计费插件;通用计费插件可复用;定义通用因子,不同业务可定制;费用项是最细粒度明细;如酒店抽佣包含了服务费&平台费用;计费项的业务视角是财务;

清算域:核心记载收付方对应后续要结的费用项及费用值;与计费实体是一对多关系;如服务费&平台费用会合到统一的平台抽佣;清算的业务视角是商户;

结算域:1、核心记载对应订单涉及的费用要以什么周期结给相关利益方,这个实体是结算单;2、记录以什么出资渠道进行打款,这个实体是打款单;抽出2个实体的原因在于结算单更多关注费用项周期特性及是否合并结算特性扩展;打款单则关注以什么渠道进行出资,扩展维度也是出资渠道;

合约域:定义商户入驻业务后涉及费用项各方收付款账号,结算周期;

物理架构

结算流程

            

        

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

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

相关文章

区块链的可拓展性研究【03】扩容整理

为什么扩容&#xff1a;在layer1上&#xff0c;交易速度慢&#xff0c;燃料价格高 扩容的目的&#xff1a;在保证去中心化和安全性的前提下&#xff0c;提升交易速度&#xff0c;更快确定交易&#xff0c;提升交易吞吐量&#xff08;提升每秒交易量&#xff09; 目前方案有&…

详解进程管理(银行家算法、死锁详解)

处理机是计算机系统的核心资源。操作系统的功能之一就是处理机管理。随着计算机的迅速发展&#xff0c;处理机管理显得更为重要&#xff0c;这主要由于计算机的速度越来越快&#xff0c;处理机的充分利用有利于系统效率的大大提高&#xff1b;处理机管理是整个操作系统的重心所…

前后端联调神器《OpenAPI-Codegen》

在后端开发完接口之后&#xff0c;前端如果再去写一遍接口来联调的话&#xff0c;会很浪费时间&#xff0c;这个时候使用OpenAPI接口文档来生成Axios接口代码的话&#xff0c;会大大提高我们的开发效率。 Axios引入 Axios是一个基于Promise的HTTP客户端&#xff0c;用于浏览器…

Go压测工具

前言 在做Go的性能分析调研的时候也使用到了一些压测方面的工具&#xff0c;go本身也给我们提供了BenchMark性能测试用例&#xff0c;可以很好的去测试我们的单个程序性能&#xff0c;比如测试某个函数&#xff0c;另外还有第三方包go-wrk也可以帮助我们做http接口的性能压测&…

C# 任务并行类库Parallel调用示例

写在前面 Task Parallel Library 是微软.NET框架基础类库&#xff08;BCL&#xff09;中的一个&#xff0c;主要目的是为了简化并行编程&#xff0c;可以实现在不同的处理器上并行处理不同任务&#xff0c;以提升运行效率。Parallel常用的方法有For/ForEach/Invoke三个静态方法…

Element-UI定制化Tree 树形控件

1.复制 说明&#xff1a;复制Tree树形控件。 <script> export default {data() {return {data: [{label: 一级 1,children: [{label: 二级 1-1,children: [{label: 三级 1-1-1}]}]}, {label: 一级 2,children: [{label: 二级 2-1,children: [{label: 三级 2-1-1}]}, {l…

Linux:进程优先级与命令行参数

目录 1.进程优先级 1.1 基本概念 1.2 查看系统进程 1.3 修改进程优先级的命令 2.进程间切换 2.1 相关概念 2.2 Linux2.6内核进程调度队列&#xff08;了解即可&#xff09; 3.命令行参数 1.进程优先级 1.1 基本概念 cpu资源分配的先后顺序&#xff0c;就是指进程的优…

利用Node.js和cpolar实现远程访问,无需公网IP和路由器设置的完美解决方案

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

LeetCode 77.组合

题目&#xff1a; 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 方法&#xff1a;灵神-组合型回溯 剪枝 class Solution {private int k;private final List<Integer> path new ArrayList<>();…

反序列化 [网鼎杯 2020 朱雀组]phpweb 1

打开题目 我们发现这个页面一直在不断的刷新 我们bp抓包一下看看 我们发现index.php用post方式传了两个参数上去&#xff0c;func和p 我们需要猜测func和p两个参数之间的关系&#xff0c;可以用php函数MD5测一下看看 我们在响应处得到了一串密文&#xff0c;md5解密一下看看 发…

Windows11安装使用Oracle21C详细步骤<图文保姆级>新版本

Windows11安装使用Oracle21C详细步骤<图文保姆级>新版本 Database Software Downloads | Oracle 中国 下载完成后解压缩 双击setup.exe 打开安装页面 同意下一步 更改自己的路径点击下一步 输入密码 下一步安装等待即可 等待加载配置时间有点久 完成即可 使用 搜索…

【Kubernetes】四层代理Service

Service四层代理 一、Service概念原理1.1、为什么要有Service1.2、Service概述1.3、工作原理1.4、三类IP地址【1】Node Network&#xff08;节点网络&#xff09;【2】Pod network&#xff08;pod 网络&#xff09;【3】Cluster Network&#xff08;服务网络&#xff09; 二、S…

C++之异常处理

C语言传统的处理错误的方式 传统的错误处理机制&#xff1a; 1. 终止程序, 如assert. 缺陷: 用户难以接受, 如发生内存错误, 除0错误时就会终止程序. 如果assert括号里面的表达式结果为假, 那么assert就会中断程序并报错, 所以使用assert可以帮助我们在程序判断一些可能出错的…

翻转二叉树(图解、前序遍历、递归与非递归)

LCR 144. 翻转二叉树 - 力扣&#xff08;LeetCode&#xff09; 给定一棵二叉树的根节点 root&#xff0c;请左右翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [5,7,9,8,3,2,4] 输出&#xff1a;[5,9,7,4,2,3,8] 提示&#xff1a; …

【11】Qt Designer

目录 VSCode添加外部工具 QtDesigner PyUIC PyRCC 加载UI文件模板代码 QMainWindow QWidget 常用知识点 1. 修改标题图标 2. 图片资源管理 3. 图片按钮 4. 加载对话框 5. 动态加载Widget 6. 修改主题 其他注意事项 事件被多次触发 PyQt5提供了一个可视化图形工…

【小沐学Python】Python实现WebUI网页图表(gradio)

文章目录 1、简介2、安装3、基本测试3.1 入门代码3.2 组件属性3.3 多个输入和输出组件3.4 图像示例3.5 聊天机器人3.6 模块&#xff1a;更灵活、更可控3.7 进度条 结语 1、简介 https://www.gradio.app/ Gradio是用友好的网络界面演示机器学习模型的最快方法&#xff0c;因此…

【T+】畅捷通T+软件安装过程中停留在:正在配置产品位置或进度80%位置。

【问题描述】 畅捷通T软件在安装过程中&#xff0c; 进度条一直停留在【正在配置产品…】位置。 【解决方法】 打开【任务管理器】&#xff0c;想必这个如何打开&#xff0c;大家应该都会。 在【进程】中找到【DBConfig.exe】或者【Ufida.T.Tool.SM.DBConfig.exe】进程并结束…

Linux 基础IO

文章目录 前言基础IO定义系统IO接口文件描述符重定向原理缓冲区刷新 前言 要知道每个函数/接口的全部参数和返回值建议去官网或者直接在Linux的man手册中查&#xff0c;这不是复制粘贴函数用法的文章。 C语言文件读写介绍链接 基础IO定义 IO是Input/Output的缩写&#xff0c…

optional

参考资料&#xff1a; Java8 Optional用法和最佳实践 - 掘金 一、背景 根据Oracle文档&#xff0c;Optional是一个容器对象&#xff0c;可以包含也可以不包含非null值。Optional在Java 8中引入&#xff0c;目的是解决 NullPointerExceptions的问题。本质上&#xff0c;Optio…

2024年网络安全竞赛-网站渗透

网站渗透 (一)拓扑图 1.使用渗透机对服务器信息收集,并将服务器中网站服务端口号作为flag提交; 使用nmap工具对靶机进行信息收集 2.使用渗透机对服务器信息收集,将网站的名称作为flag提交; 访问页面即可 3.使用渗透机对服务器渗透,将可渗透页面的名称作为flag提交…