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网站 ...
随机推荐
- DockerCon 2016 – 微软带来了什么?
根据Forrester的调查,接近半数的企业CIO在考虑IT架构的时候更乐于接受开源方案,这主要是基于低成本,避免供应商锁定和敏捷的需求:同时另外一家North Bridge的调研机构的调查显示,20 ...
- Spring Quartz实现任务调度
任务调度 在企业级应用中,经常会制定一些"计划任务",即在某个时间点做某件事情 核心是以时间为关注点,即在一个特定的时间点,系统执行指定的一个操作 任务调度涉及多线程并发.线程池维 ...
- Mono on CentOS 6.3 安装笔记
在网上找到篇关于yum的文章,写的很详细特此推荐下,在阅读本文之前建议先看看它: <CentOS yum源的配置与使用> 如果用的是移动光驱,建议不要开启本地的yum 的本地reposit ...
- 腾讯云上免费部署HTTPS
接上篇<腾讯云下安装 nodejs + 实现 Nginx 反向代理>,想从头一步到位的同学建议从上篇文章开始阅读.本文将继续介绍如何通过 Nginx 免费部署HTTPS. 留意下,这里的“ ...
- 页面与ViewModel(上)
在UWP淘宝与旺信中,笔者主要负责页面与控件的制作,这些工作看似简单,但要想做的全面细致仍然需要深入的思考.本文想分享一些在UWP旺信的制作过程中,笔者在UI页面与控件制作上体会到的一些心得.可能笔者 ...
- API Monitor简介(API监控工具)
API Monitor是一个免费软件,可以让你监视和控制应用程序和服务,取得了API调用. 它是一个强大的工具,看到的应用程序和服务是如何工作的,或跟踪,你在自己的应用程序的问题. 64位支持 API ...
- Windbg Extension NetExt 使用指南 【2】 ---- NetExt 的基本命令介绍
摘要 : 本章节介绍NetExt常用的命令. 并且对SOS进行一些对比. NetExt的帮助 要想玩好NetExt, 入门就得看帮助. 看NetExt的帮助可以调用!whelp 命令. 这样hi列举出 ...
- 常用数据库的驱动程序和Url地址
常用数据库的驱动程序及JDBC URL: Oracle数据库: 驱动程序包名:ojdbc6.jar 驱动类的名字:oracle.jdbc.driver.OracleDriver JDBC URL:jd ...
- js变量声明作用域问题
1.先来看两个题 var a = 1; foo1(); function foo1(){ console.log(a); //输出1 }; foo2(); var a = 1; function fo ...
- JavaScript随笔7
BOM (1). window.open('窗口','_self或者_blank');//打开一个新的浏览器窗口 例 var win = window.open('about:blank');//获取 ...