TYPESDK手游聚合SDK服务端设计思路与架构之三:流程优化之订单保存与通知
经过前两篇文字的分析与设计,我们已经可以搭建出一个能够支持多游戏多渠道的聚合SDK服务端,但这只是理想化状态下的一个简化模型。如果接入渠道的逻辑都是按照理想化的简化过程来构建,那么对于支付的请求,我们可以简化成这样几步:
- 游戏客户端创建订单。
- 游戏客户端(通过TYPESDK客户端)调用渠道lib库中相应接口,发起支付。
- 用户在弹出的支付窗口完成支付。
- TYPESDK服务端等待渠道服务端的回调,收到回调后通知游戏服务端。
- 游戏服务端执行发货动作。
但是显然这个简化流程在实际上线时是不够满足需求的,例如第一步的创建订单,在实践中就是不应该由游戏客户端来完成的。订单的创建和状态管理,都应该由游戏服务端来控制,当然,这个修改需要游戏开发时做好支持。下面我们就来考虑一个常见的流程问题,需要TYPESDK服务端和游戏服务端来共同处理。
默认场景下,多数渠道技术框架的设计都是默认一个游戏只有一个服务器回调地址,并不会考虑一个游戏存在多个区服服,多个回调地址的情况。当然更不需要考虑TYPESDK这种多游戏共用统一回调地址的需求场景。所以我们需要在设计SDK服务端时,让系统可以识别渠道发来的回调订单究竟属于哪个游戏的哪个区服,据此向对应的服务器发送发货通知。
但是如我们所知,接收到不同渠道的回调请求时,我们可以获取到的信息是不固定的,没有统一判断的信息。大多数渠道的回调信息中除了订单本身相关的信息,比如支付金额商品名称之外,最多提供一些诸如用户信息和安全性校验相关的信息。而可以利用的字段,最常见的情况就是只有一个叫扩展信息的字段。
这个扩展信息字段,在不同的渠道文档里有不同的名称,诸如“扩展字段”,“透传字段”,“自定义信息”,“保留信息”等,或者诸如此类的其他名称。这个字段在下订单时从游戏客户端传送给渠道服务端并作为订单的一部分保存起来,渠道不会对其做任何处理,在支付完成时,将它原样回调发给游戏服务端。通常,我们用这个字段传送游戏内部产生的订单号。我们需要这个字段发挥更多作用,比如传递订单的游戏信息,区服信息等等等等。但是,首先网络传输的时候,并不合适传送太长的信息;其次,很多渠道还人为限制了这个字段的长度。比较夸张的,只留给了开发者12位的长度限制,要在这么短的字段里强行塞进各种信息,并不合适。
TYPESDK服务端作为开发者自己搭建的统一接入后台,当然同样可以用来保存我们需要的信息。所以我们可以在TYPESDK服务端里存储一份订单信息,这个信息的主键是游戏服务器创建的内部订单号,而内容则包括订单的一些更详细的信息比如创建时间,订单金额,以及订单回调的区服信息。这样,在收到渠道发来的一份特定订单的回调信息时,就可以简单的根据这份订单的内部订单号获取到对应区服的回调地址了。
游戏区服回调地址可以使用配置的方式保存在TYPESDK服务端,然后根据保存订单的区服信息查询。但是更简单的方案是,在保存订单时,由游戏服务器直接在保存订单的时候将完整的URL作为一个字段,传送给TYPESDK服务端,作为订单的信息直接保存起来。
根据以上的做法,改进后的支付-充值流程如下图所述:

流程说明
- 用户点击某商品的购买按钮时,游戏客户端访问游戏服务器
l 每次点击购买均需要访问游戏服务器并创建内部订单号,并非完成完整支付时才创建
- 游戏服务端创建内部订单,生成内部订单号并调用TYPESDK服务端的充值信息提交接口
- TYPESDK服务端保存订单信息。返回提交处理结果
- 游戏服务端将生成的内部订单号返回游戏客户端
- 游戏客户端使用内部订单号调用TYPESDK客户端支付接口
- TYPESDK客户端调用渠道客户端SDK的API弹出支付窗
l 用户在支付窗完成支付
- 渠道SDK客户端提交订单至渠道服务端
- 渠道服务端返回充值请求已接受消息至渠道SDK客户端
l 此时充值尚未到帐,充值到帐是一个异步动作。这里返回的消息表示充值动作完成,请求已接受。
- 渠道SDK客户端处理请求已接受消息。返回TYPESDK客户端
- TYPESDK客户端包装请求已接受消息,返回游戏客户端
- 游戏客户端将请求已接受消息通知游戏服务端,修改订单状态
至此就完成了支付流程中的充值这一过程,用户完成了支付金钱给渠道平台。随后渠道平台在确认到帐之后,会异步处理该订单,然后以回调的形式,通知TYPESDK服务端。TYPESDK服务端收到该回调时,就可以根据回调中的内部订单号字段,查询到该订单对应的游戏区服回调地址,并通知对应的游戏服务器了。
回头看我们在本系列文字第一篇里做出的简单充值到帐流程图,就可以将该流程修改如下图所示:

流程说明
- 充值订单到帐后,渠道服务端异步通知TYPESDK服务端
- TYPESDK服务端根据内部订单号查询该订单信息
- TYPE服务端通知游戏服务端发货
- 游戏服务端收到发货请求后先保存该请求,立刻返回TYPESDK服务端,表示已收到发货请求。
- TYPESDK返回渠道服务端
- 游戏服务端异步处理发货逻辑。并通知游戏客户端
这样,我们就比较圆满的解决了这一实际场景中常见的需求。下一章,我们会继续分析这一流程中存在的其他问题,并讨论如何解决。
这个项目已开源,大家有兴趣可以自己研究或者参照项目编写自己的聚合SDK
项目地址:https://code.csdn.net/typesdk_code
项目地址:https://github.com/typesdk
TYPESDK手游聚合SDK服务端设计思路与架构之三:流程优化之订单保存与通知的更多相关文章
- TYPESDK手游聚合SDK服务端设计思路与架构之一:应用场景分析
TYPESDK 服务端设计思路与架构之一:应用场景分析 作为一个渠道SDK统一接入框架,TYPESDK从一开始,所面对的需求场景就是多款游戏,通过一个统一的SDK服务端,能够同时接入几十个甚至几百个各 ...
- TYPESDK手游聚合SDK服务端设计思路与架构之二:服务端设计
在前一篇文中,我们对一个聚合SDK服务端所需要实现的功能作了简单的分析.通过两个主要场景的功能流程图,我们可以看到,作为多款游戏要适配多个渠道的统一请求转发中心,TYPESDK服务端主要需要实现的功能 ...
- TYPESDK手游聚合SDK服务端设计思路与架构之四:流程优化之信息安全与订单校验
有了前文几个步骤的分析和设计,TYPESDK的信息交互流程已经可以正常工作了,但是,这个流程还没有考虑到支付这样的过程中,至关重要的信息安全问题. 在整个交互过程中,游戏服务端,SDK服务端,渠道服务 ...
- TYPESDK手游聚合SDK客户端远程开关:渠道支付黑名单
渠道支付要做开关干嘛用呢?为什么要做这种东西呢? 这个教训来分享一下,我们的游戏上线公测了,59个渠道首发,其中包括了应用宝,UC,360等的大渠道,也包含有一些工会渠道和小渠道,上线后一切正常,但是 ...
- 手游聚合SDK开发之远程开关---渠道登入白名单
白名单有啥好说的呢?无非就是筛选登入,大家第一眼看到就是这个印象,白名单也是有文章的,弄的时机不同会给你带来很不错的收益,注意是收益.还是举例来说,游戏上线前渠道都会做一个预下载,一般提前1-2天,这 ...
- 谈反应式编程在服务端中的应用,数据库操作优化,提速 Upsert
反应式编程在客户端编程当中的应用相当广泛,而当前在服务端中的应用相对被提及较少.本篇将介绍如何在服务端编程中应用响应时编程来改进数据库操作的性能. 开篇就是结论 接续上一篇<谈反应式编程在服务端 ...
- 服务端高并发分布式架构 ESB 企业服务总线
服务端高并发分布式架构演进之路 - 个人文章 - SegmentFault 思否 https://segmentfault.com/a/1190000018626163 ESB 企业服务总线讲解 ht ...
- rsync服务端排错思路
rsync服务端排错思路 rsync服务端排错思路 查看rsync服务配置文件路径是否正确,正确的默认路径为/etc/rsyncd.conf 查看配置文件里host allow,host ...
- 移动APP服务端设计开发注意要点
2014年,移动APP的热度丝毫没有减退,怎么为您的移动端app设计良好的服务器端接口(API)呢? 下面谈谈我个人的一些想法. 2014年,移动APP的热度丝毫没有减退,并没有像桌面软件被WEB网站 ...
随机推荐
- C++常见笔试面试要点以及常见问题
1. C++常见笔试面试要点: C++语言相关: (1) 虚函数(多态)的内部实现 (2) 智能指针用过哪些?shared_ptr和unique_ptr用的时候需要注意什么?shared_ptr的实现 ...
- 使用Microsoft的IoC框架:Unity来对.NET应用进行解耦
1.IoC/DI简介 IoC 即 Inversion of Control,DI 即 Dependency Injection,前一个中文含义为控制反转,后一个译为依赖注入,可以理解成一种编程模式,详 ...
- web服务器集群
概述 集群和分布式都是从集中式进化而来的.分布式和集群会相互合作的,同时的集群和分布式.在这里重点说说集群 集群是什么? 集群能提高单位时间内处理的任务数量,提升服务器性能 有多台服务器去处理任务,但 ...
- 解决WINDOWS防火墙开启后Ping不通
WINDOWS系统由于安全考虑,当开启防火墙时,默认不允许外主机对其进行ping功能,即别的电脑ping不通本机.别的主机ping不通本机是因为本机的防火墙关闭了ICMP回显功能,只要把这回显功能打开 ...
- Jexus Web Server 完全傻瓜化图文配置教程(基于Ubuntu 12.04.3 64位)[内含Hyper-v 2012虚拟机镜像下载地址]
1. 前言 近日有感许多新朋友想尝试使用Jexus,不过绝大多数都困惑徘徊在Linux如何安装啊,如何编译Mono啊,如何配置Jexus啊...等等基础问题,于是昨日向宇内流云兄提议,不如搞几个配置好 ...
- ASP.NET 5 和Entity Framework 7公告仓库
ASP.NET 5 有一个公告仓库来介绍ASP.NET 5和 Entity Framework 7的主要变更说明,这个对于日夜更新的项目来说,很多人经常会遇到问题但是不知道去哪里寻找帮助,很多同学在做 ...
- VS2013默认打开HTML文件没有设计视图的解决办法
VS菜单->工具->选项->文本编辑器->文件扩展名,右侧输入html,再下拉列表选HTML(Web窗体)编辑器,点添加,确定. 重新打开html文件,就出现“设计”视图了
- Atitit 图像处理的摩西五经attilax总结
Atitit 图像处理的摩西五经attilax总结 1. 数字图像处理(第三版)1 2. 图像处理基础(第2版)(世界著名计算机教材精选)1 3. 计算机视觉特征提取与图像处理(第三版)2 4. Op ...
- EXISTS 引入子查询时,在选择列表中只能指定一个表达式
- CSS系列目录
1. 在HTML中引入CSS的方法 2. CSS选择器 2.1 CSS3新增选择器 3. CSS的继承与层叠特性 4. CSS中盒子模型 5. CSS中盒子之间的关系 6. CSS中盒子的 ...